

# MCX A153, A152,A143, A142 Reference Manual

Supports MCX A142VLH, MCX A142VFT, MCX A142VFM, MCX A143VLH, MCX A143VFT, MCX A143VFM, MCX A152VLH, MCX A152VFT, MCX A152VFM, MCX A153VLH, MCX A153VFT, MCX A153VFM



# Contents

|                                                          |           |
|----------------------------------------------------------|-----------|
| <b>Chapter 1 About This Manual.....</b>                  | <b>10</b> |
| 1.1 Audience.....                                        | 10        |
| 1.2 Organization.....                                    | 10        |
| 1.3 Module descriptions.....                             | 10        |
| 1.4 Register descriptions.....                           | 13        |
| 1.5 Conventions.....                                     | 15        |
| 1.6 Editorial changes.....                               | 16        |
| <br>                                                     |           |
| <b>Chapter 2 Introduction.....</b>                       | <b>18</b> |
| 2.1 Overview.....                                        | 18        |
| 2.2 Target applications.....                             | 18        |
| 2.3 Block diagram.....                                   | 18        |
| 2.4 Features.....                                        | 19        |
| 2.5 Functional overview.....                             | 20        |
| <br>                                                     |           |
| <b>Chapter 3 Core Overview.....</b>                      | <b>27</b> |
| 3.1 Introduction.....                                    | 27        |
| 3.2 Cortex-M33 Code and System buses.....                | 27        |
| 3.3 Nested Vectored Interrupt Controller (NVIC).....     | 27        |
| 3.4 System memory map.....                               | 28        |
| 3.5 Peripheral Bridge .....                              | 28        |
| <br>                                                     |           |
| <b>Chapter 4 Bus and Memory Architecture.....</b>        | <b>29</b> |
| 4.1 Bus and Memory architecture.....                     | 29        |
| 4.2 System bus priority and arbitration.....             | 30        |
| 4.3 SRAM configuration.....                              | 31        |
| 4.4 Read Only Memory (ROM).....                          | 33        |
| 4.5 Flash subsystem.....                                 | 33        |
| <br>                                                     |           |
| <b>Chapter 5 Low Power Cache Controller (LPCAC).....</b> | <b>35</b> |
| 5.1 Chip-specific LPCAC information.....                 | 35        |
| 5.2 Overview.....                                        | 35        |
| 5.3 Functional description.....                          | 36        |
| 5.4 Signal descriptions.....                             | 37        |
| 5.5 Memory regions and input control description.....    | 37        |
| <br>                                                     |           |
| <b>Chapter 6 Flash Memory Module (FMU).....</b>          | <b>39</b> |
| 6.1 Chip-specific FMU information.....                   | 39        |
| 6.2 Overview.....                                        | 39        |
| 6.3 Functional description.....                          | 40        |
| 6.4 External signals.....                                | 57        |
| 6.5 Initialization.....                                  | 57        |
| 6.6 Memory map and registers.....                        | 57        |
| 6.7 Glossary.....                                        | 69        |

|                                                            |            |
|------------------------------------------------------------|------------|
| <b>Chapter 7 Flash Memory Controller (FMC).....</b>        | <b>71</b>  |
| 7.1 Chip-specific FMC information.....                     | 71         |
| 7.2 Overview.....                                          | 71         |
| 7.3 Functional description.....                            | 72         |
| 7.4 External signals.....                                  | 74         |
| 7.5 Initialization and application information.....        | 74         |
| 7.6 Register descriptions.....                             | 74         |
| <b>Chapter 8 Error Injection Module (EIM).....</b>         | <b>77</b>  |
| 8.1 Chip-specific EIM information.....                     | 77         |
| 8.2 Overview.....                                          | 78         |
| 8.3 Functional description.....                            | 80         |
| 8.4 Initialization.....                                    | 80         |
| 8.6 EIM register descriptions.....                         | 80         |
| <b>Chapter 9 Error Reporting Module (ERM).....</b>         | <b>88</b>  |
| 9.1 Chip-specific ERM information.....                     | 88         |
| 9.2 Overview.....                                          | 88         |
| 9.3 Functional description.....                            | 89         |
| 9.4 Initialization.....                                    | 91         |
| 9.5 ERM register descriptions.....                         | 91         |
| <b>Chapter 10 Signal Multiplexing.....</b>                 | <b>99</b>  |
| 10.1 Introduction.....                                     | 99         |
| 10.2 Pinout.....                                           | 99         |
| 10.3 Pinmux view.....                                      | 99         |
| <b>Chapter 11 Port Control (PORT).....</b>                 | <b>108</b> |
| 11.1 Chip-specific PORT information.....                   | 108        |
| 11.2 Overview.....                                         | 108        |
| 11.3 Functional description.....                           | 109        |
| 11.4 Initialization.....                                   | 110        |
| 11.5 Application information.....                          | 110        |
| 11.6 Memory map and register definition.....               | 110        |
| <b>Chapter 12 General Purpose Input/Output (GPIO).....</b> | <b>199</b> |
| 12.1 Chip-specific GPIO information.....                   | 199        |
| 12.2 Overview.....                                         | 199        |
| 12.3 Functional description.....                           | 200        |
| 12.4 External signals .....                                | 203        |
| 12.5 Initialization.....                                   | 203        |
| 12.6 Application information.....                          | 203        |
| 12.7 Memory map and register definition.....               | 203        |
| <b>Chapter 13 Input Multiplexing (INPUTMUX).....</b>       | <b>219</b> |
| 13.1 Chip-specific INPUTMUX information.....               | 219        |
| 13.2 Overview.....                                         | 219        |
| 13.3 Functional description.....                           | 220        |
| 13.4 External signals.....                                 | 220        |

|                                                       |            |
|-------------------------------------------------------|------------|
| 13.5 Memory map and register definition.....          | 221        |
| <b>Chapter 14 System Controller (SYSCON).....</b>     | <b>302</b> |
| 14.1 Chip-specific SYSCON information.....            | 302        |
| 14.2 Overview.....                                    | 302        |
| 14.3 Functional description.....                      | 303        |
| 14.4 Signals.....                                     | 303        |
| 14.5 Memory map and register definition.....          | 303        |
| 14.6 Application information.....                     | 406        |
| <b>Chapter 15 Enhanced DMA Controller (eDMA).....</b> | <b>407</b> |
| 15.1 Chip-specific eDMA information.....              | 407        |
| 15.2 Overview.....                                    | 407        |
| 15.3 Functional description.....                      | 410        |
| 15.4 External signals.....                            | 415        |
| 15.5 Initialization.....                              | 415        |
| 15.6 Memory map/register definition.....              | 427        |
| <b>Chapter 16 Wakeup Unit (WUU).....</b>              | <b>467</b> |
| 16.1 Chip-specific WUU information.....               | 467        |
| 16.2 Overview.....                                    | 469        |
| 16.3 Functional description.....                      | 471        |
| 16.4 External signals.....                            | 472        |
| 16.5 Initialization.....                              | 472        |
| 16.6 Application information.....                     | 473        |
| 16.7 Memory map and register definition.....          | 473        |
| <b>Chapter 17 AND/OR INVERT (AOI).....</b>            | <b>514</b> |
| 17.1 Chip-specific AOI information.....               | 514        |
| 17.2 Overview.....                                    | 514        |
| 17.3 Functional description.....                      | 516        |
| 17.4 External signals .....                           | 516        |
| 17.5 Initialization.....                              | 516        |
| 17.6 Application information.....                     | 516        |
| 17.7 AOI register descriptions.....                   | 518        |
| <b>Chapter 18 Core Mode Controller (CMC).....</b>     | <b>524</b> |
| 18.1 Chip-specific CMC information.....               | 524        |
| 18.2 Overview.....                                    | 524        |
| 18.3 Functional description.....                      | 524        |
| 18.4 External signals.....                            | 531        |
| 18.5 Initialization.....                              | 531        |
| 18.6 Application information.....                     | 531        |
| 18.7 Memory map and register descriptions.....        | 532        |
| <b>Chapter 19 Reset.....</b>                          | <b>559</b> |
| 19.1 Reset sources.....                               | 559        |
| 19.2 Power reset sources.....                         | 559        |
| 19.3 External reset sources.....                      | 560        |

|                                                                   |            |
|-------------------------------------------------------------------|------------|
| 19.4 Internal reset sources.....                                  | 561        |
| 19.5 Reset type.....                                              | 562        |
| <b>Chapter 20 Boot ROM.....</b>                                   | <b>565</b> |
| 20.1 MCXA1 Boot ROM.....                                          | 565        |
| 20.2 Boot ROM.....                                                | 565        |
| 20.3 Life Cycle.....                                              | 580        |
| 20.4 Debugger Mailbox Access Port and Debug session protocol..... | 582        |
| 20.5 Extended Bootloader and In-System programming (ISP).....     | 586        |
| <b>Chapter 21 Clocking.....</b>                                   | <b>621</b> |
| 21.1 Introduction.....                                            | 621        |
| 21.2 Configure main clock and system clock.....                   | 621        |
| 21.3 Clock generation.....                                        | 621        |
| <b>Chapter 22 System Clock Generator (SCG).....</b>               | <b>632</b> |
| 22.1 Chip-specific SCG information.....                           | 632        |
| 22.2 Overview.....                                                | 632        |
| 22.3 Functional description.....                                  | 634        |
| 22.4 External signals.....                                        | 637        |
| 22.5 Initialization.....                                          | 637        |
| 22.6 Application information.....                                 | 637        |
| 22.7 Memory map and register definition.....                      | 639        |
| <b>Chapter 23 Power Management.....</b>                           | <b>667</b> |
| 23.1 Introduction.....                                            | 667        |
| 23.2 Power domains.....                                           | 667        |
| 23.3 Power modes.....                                             | 669        |
| 23.4 Deep Power Down mode.....                                    | 671        |
| 23.5 Module operation in low power modes.....                     | 671        |
| 23.6 Power optimization.....                                      | 673        |
| <b>Chapter 24 VBAT.....</b>                                       | <b>676</b> |
| 24.1 Chip-specific VBAT information.....                          | 676        |
| 24.2 Overview.....                                                | 676        |
| 24.3 Functional description.....                                  | 677        |
| 24.4 Initialization.....                                          | 677        |
| 24.5 Memory map and register definition.....                      | 678        |
| <b>Chapter 25 System Power Control (SPC).....</b>                 | <b>684</b> |
| 25.1 Chip-specific SPC information.....                           | 684        |
| 25.2 Overview.....                                                | 685        |
| 25.3 Functional description.....                                  | 686        |
| 25.4 External signals.....                                        | 691        |
| 25.5 Initialization.....                                          | 691        |
| 25.6 Application information.....                                 | 691        |
| 25.7 SPC register descriptions.....                               | 691        |

|                                                                       |            |
|-----------------------------------------------------------------------|------------|
| <b>Chapter 26 Standard Counter or Timer (CTIMER).....</b>             | <b>723</b> |
| 26.1 Chip-specific CTIMER information.....                            | 723        |
| 26.2 Overview.....                                                    | 724        |
| 26.3 Functional description.....                                      | 726        |
| 26.4 External signals.....                                            | 728        |
| 26.5 Initialization.....                                              | 729        |
| 26.6 Application information.....                                     | 729        |
| 26.7 CTIMER register descriptions.....                                | 729        |
| <b>Chapter 27 Windowed Watchdog Timer (WWDT).....</b>                 | <b>749</b> |
| 27.1 Chip-specific WWDT information.....                              | 749        |
| 27.2 Overview.....                                                    | 749        |
| 27.3 Functional description.....                                      | 751        |
| 27.4 External signals .....                                           | 753        |
| 27.5 Initialization.....                                              | 754        |
| 27.6 Memory map and register definition.....                          | 754        |
| <b>Chapter 28 Micro-Tick Timer (UTICK).....</b>                       | <b>762</b> |
| 28.1 Chip-specific UTICK information.....                             | 762        |
| 28.2 Overview.....                                                    | 762        |
| 28.3 Functional description.....                                      | 763        |
| 28.4 External signals.....                                            | 763        |
| 28.5 Initialization.....                                              | 763        |
| 28.6 UTICK register descriptions.....                                 | 764        |
| <b>Chapter 29 OS Event Timer (OSTIMER).....</b>                       | <b>771</b> |
| 29.1 Chip-specific OSTIMER information.....                           | 771        |
| 29.2 Overview.....                                                    | 771        |
| 29.3 Functional description.....                                      | 772        |
| 29.4 External signals.....                                            | 773        |
| 29.5 Initialization.....                                              | 773        |
| 29.6 Memory map and register definition.....                          | 773        |
| <b>Chapter 30 Wake-Up Timer.....</b>                                  | <b>781</b> |
| 30.1 Chip-specific Wake-up Timer information.....                     | 781        |
| 30.2 Overview.....                                                    | 781        |
| 30.3 Functional description.....                                      | 782        |
| 30.4 External signals.....                                            | 782        |
| 30.5 Memory map and register description.....                         | 782        |
| <b>Chapter 31 Enhanced Flex Pulse Width Modulator (eFlexPWM).....</b> | <b>785</b> |
| 31.1 Chip-specific eFlexPWM information.....                          | 785        |
| 31.2 Overview.....                                                    | 785        |
| 31.3 Functional description.....                                      | 787        |
| 31.4 External Signals.....                                            | 817        |
| 31.5 PWM register descriptions.....                                   | 818        |
| <b>Chapter 32 Quadrature Decoder (QDC).....</b>                       | <b>879</b> |
| 32.1 Chip-specific QDC information.....                               | 879        |

|                                                                                           |             |
|-------------------------------------------------------------------------------------------|-------------|
| 32.2 Overview.....                                                                        | 879         |
| 32.3 Functional description.....                                                          | 880         |
| 32.4 External signals.....                                                                | 902         |
| 32.5 Initialization.....                                                                  | 904         |
| 32.6 Register descriptions.....                                                           | 904         |
| <b>Chapter 33 Frequency Measurement (FREQME).....</b>                                     | <b>945</b>  |
| 33.1 Chip-specific FREQME information.....                                                | 945         |
| 33.2 Overview.....                                                                        | 946         |
| 33.3 Functional description.....                                                          | 946         |
| 33.4 External signals.....                                                                | 947         |
| 33.5 Initialization.....                                                                  | 948         |
| 33.6 Memory map and register definition.....                                              | 948         |
| <b>Chapter 34 Low-Power Timer (LPTMR).....</b>                                            | <b>957</b>  |
| 34.1 Chip-specific LPTMR information.....                                                 | 957         |
| 34.2 Overview.....                                                                        | 958         |
| 34.3 Functional description.....                                                          | 958         |
| 34.4 External signals.....                                                                | 961         |
| 34.5 Initialization.....                                                                  | 961         |
| 34.6 Application information.....                                                         | 961         |
| 34.7 Memory map and register definition.....                                              | 962         |
| <b>Chapter 35 USB Full Speed (FS) Device Controller.....</b>                              | <b>969</b>  |
| 35.1 Chip-specific USBFS information.....                                                 | 969         |
| 35.2 Overview.....                                                                        | 969         |
| 35.3 Functional description.....                                                          | 971         |
| 35.4 External signals.....                                                                | 980         |
| 35.5 Initialization.....                                                                  | 980         |
| 35.6 Application information.....                                                         | 980         |
| 35.7 Memory map and register definitions.....                                             | 981         |
| <b>Chapter 36 Low Power Inter-Integrated Circuit (LPI2C).....</b>                         | <b>1023</b> |
| 36.1 Chip-specific LPI2C information.....                                                 | 1023        |
| 36.2 Overview.....                                                                        | 1023        |
| 36.3 Functional description.....                                                          | 1025        |
| 36.4 External signals.....                                                                | 1036        |
| 36.5 Initialization.....                                                                  | 1037        |
| 36.6 Application information.....                                                         | 1038        |
| 36.7 Memory map and registers.....                                                        | 1038        |
| <b>Chapter 37 Low Power Universal Asynchronous Receiver/Transmitter<br/>(LPUART).....</b> | <b>1092</b> |
| 37.1 Chip-specific LPUART information.....                                                | 1092        |
| 37.2 Overview.....                                                                        | 1092        |
| 37.3 Functional description.....                                                          | 1095        |
| 37.4 External signals.....                                                                | 1107        |
| 37.5 Initialization.....                                                                  | 1107        |
| 37.6 Register definition.....                                                             | 1107        |

|                                                                      |             |
|----------------------------------------------------------------------|-------------|
| <b>Chapter 38 Low Power Serial Peripheral Interface (LPSPI).....</b> | <b>1144</b> |
| 38.1 Chip-specific LPSPI information.....                            | 1144        |
| 38.2 Overview.....                                                   | 1144        |
| 38.3 Functional description.....                                     | 1146        |
| 38.4 External signals.....                                           | 1157        |
| 38.5 Initialization.....                                             | 1158        |
| 38.6 Memory map and registers.....                                   | 1159        |
| <b>Chapter 39 Improved Inter-Integrated Circuit (I3C).....</b>       | <b>1193</b> |
| 39.1 Chip-specific MIPI I3C information.....                         | 1193        |
| 39.2 Overview.....                                                   | 1193        |
| 39.3 Functional description.....                                     | 1195        |
| 39.4 External signals.....                                           | 1209        |
| 39.5 Initialization.....                                             | 1210        |
| 39.6 Application information.....                                    | 1212        |
| 39.7 I3C register descriptions.....                                  | 1212        |
| <b>Chapter 40 Analog-to-Digital Converter (ADC).....</b>             | <b>1308</b> |
| 40.1 Chip-specific ADC information.....                              | 1308        |
| 40.2 Overview.....                                                   | 1310        |
| 40.3 Functional description.....                                     | 1312        |
| 40.4 External signals.....                                           | 1322        |
| 40.5 Initialization.....                                             | 1323        |
| 40.6 ADC register descriptions.....                                  | 1325        |
| <b>Chapter 41 Low-Power Comparator (CMP).....</b>                    | <b>1365</b> |
| 41.1 Chip-specific CMP information.....                              | 1365        |
| 41.2 Overview.....                                                   | 1367        |
| 41.3 Functional Description.....                                     | 1369        |
| 41.4 External signal descriptions.....                               | 1382        |
| 41.5 Initialization.....                                             | 1382        |
| 41.6 Application information.....                                    | 1383        |
| 41.7 LPCMP register descriptions.....                                | 1384        |
| <b>Chapter 42 Debug.....</b>                                         | <b>1405</b> |
| 42.1 Introduction.....                                               | 1405        |
| 42.2 Debug/Trace component.....                                      | 1406        |
| 42.3 Test and debug port connectivity.....                           | 1407        |
| 42.4 Debug ROM tables.....                                           | 1409        |
| 42.5 Low power debug.....                                            | 1409        |
| 42.6 Halting execution immediately following ROM execution.....      | 1410        |
| <b>Chapter 43 Debug Mailbox.....</b>                                 | <b>1411</b> |
| 43.1 Chip-specific DBG_MAILBOX information.....                      | 1411        |
| 43.2 Overview.....                                                   | 1411        |
| 43.3 Functional description.....                                     | 1412        |
| 43.4 External signals.....                                           | 1419        |
| 43.5 Memory map and register definition.....                         | 1420        |

|                                                      |             |
|------------------------------------------------------|-------------|
| <b>Chapter 44 Cyclic Redundancy Check (CRC).....</b> | <b>1424</b> |
| 44.1 Chip-specific CRC information.....              | 1424        |
| 44.2 Overview.....                                   | 1424        |
| 44.3 Functional description.....                     | 1425        |
| 44.4 External signals.....                           | 1427        |
| 44.5 Initialization.....                             | 1427        |
| 44.6 Use cases.....                                  | 1428        |
| 44.7 Memory map and register descriptions.....       | 1430        |
| <b>Chapter 45 Memory Block Checker(MBC).....</b>     | <b>1435</b> |
| 45.1 Chip-specific MBC information.....              | 1435        |
| 45.2 Overview.....                                   | 1435        |
| 45.3 Functional description.....                     | 1436        |
| 45.4 External signals.....                           | 1438        |
| 45.5 Register descriptions.....                      | 1439        |
| <b>Chapter 46 Code Watchdog Timer (CDOG).....</b>    | <b>1470</b> |
| 46.1 Chip-specific CDOG information.....             | 1470        |
| 46.2 Overview.....                                   | 1470        |
| 46.3 Functional description.....                     | 1471        |
| 46.4 Application information.....                    | 1475        |
| 46.5 Memory map and register definition.....         | 1476        |
| <b>Chapter 47 GLIKEY.....</b>                        | <b>1496</b> |
| 47.1 Chip-specific GLIKEY information.....           | 1496        |
| 47.2 Terms and definitions.....                      | 1496        |
| 47.3 Overview.....                                   | 1497        |
| 47.4 Configuration.....                              | 1497        |
| 47.5 Architecture description.....                   | 1497        |
| <b>Legal information.....</b>                        | <b>1502</b> |

# Chapter 1

## About This Manual

### 1.1 Audience

This reference manual (RM) is intended for system software, hardware developers, and applications programmers who need to develop products using this chip. It assumes that its users understand operating systems, microprocessor system design, and basic principles of software and hardware.

### 1.2 Organization

This manual has two main sets of chapters.

- Chapters in the first set contain information that applies to all components on the chip.
- Chapters in the second set are organized into functional groupings that detail particular areas of functionality.
  - Examples of these groupings are clocking, timers, and communication interfaces.
  - Each grouping includes chapters that provide a technical description of individual modules.

#### 1.2.1 Attachments

This manual includes key information in the files attached to it. For example, memory map and I/O details. Use the content in these attachments in conjunction with this manual's content.

---

##### NOTE

Select the paperclip icon on the left side of the PDF window to see the list of attachments.

---

### 1.3 Module descriptions

Each module chapter has two main parts:

- The first section, *chip-specific [module name]* information, provides details such as the number of module instances on the chip and connections between that module and the other ones. Read this section *first* because its content is crucial for understanding the information in the other sections of the chapter.
- The subsequent sections provide general information about the module, including its signals, registers, and functional description.

The following figure shows you an example of this demarcation.



## Chapter 49 Enhanced Serial Communication Interface (eSCI)

### 49.1 Chip-specific eSCI information

This chip has six instances of the eSCI module. Some feature details vary between the instances.

The following table summarizes the feature differences. The table does not list feature details that the instances share.

| Instance                           | DMA support                                                                |
|------------------------------------|----------------------------------------------------------------------------|
| eSCI_A and eSCI_B                  | Yes                                                                        |
| eSCI_C, eSCI_D, eSCI_E, and eSCI_F | No: descriptions of eSCI DMA functionality do not apply to these instances |

**NOTE**  
For eSCI\_D, the single wire feature does not apply for TX/RX via PCSA3 because this pad works only as an output.

### 49.2 Introduction

The eSCI block is an enhanced SCI block with a LIN master interface layer and DMA support. The LIN master layer complies with the specifications LIN 1.3, LIN 2.0, LIN 2.1, and SAE J2602/1.

#### 49.2.1 Bibliography

- LIN Specification Package Revision 1.3; December 12, 2002
- LIN Specification Package Revision 2.0; September 23, 2003

---

Sample Reference Manual

Chip-specific information  
that should be read first

Beginning of general  
module information

Figure 1. Example of chapter chip-specific information and general module information

### 1.3.1 Chip-specific information that clarifies content in the same chapter

The following figure shows an example of chip-specific information that clarifies general module information presented later in the chapter. In this case, the chip-specific register reset values supersede the reset values that appear in the register diagram.

MCX A153, A152,A143, A142 Reference Manual, Rev. 4, 01/2024

Reference Manual

11 / 1504

Introduction

**System Integration Unit Lite2 (SIUL2)**

## Chapter 9 System Integration Unit Lite2 (SIUL2)

### 9.1 Chip-specific SIUL2 information

#### 9.1.1 Feature configurations

In this device, the SIUL2\_0 module instance does not support the following features described in the generic description:

- Interrupts
- DMA channels

#### 9.1.2 Notes for IMCR

Out of reset, PA\_00, PA\_04, and PA\_05 pads have JTAG input functionality selected by default. It should be disabled in the corresponding IMCR registers (IMCR61, IMCR60, and IMCR50 respectively) in order to use other functionality such as GPIO.

### 9.2 Introduction

#### 9.2.1 Overview

The System Integration Unit Lite2 provides control over all the electrical pin controls and ports with 16 bits of bidirectional, general-purpose input and output signals. One of the most important functions of the SIUL2 is to enable the user to select the functions and electrical characteristics that appear on external device pins. It also controls the multiplexing of internal signals from one module to another and controls chip I/O. It supports as many as 32 external interrupts with trigger event configuration. The following figure is the block diagram of SIUL2 and its interfaces to other system components.

**Figure 23. System Integration Unit Lite2 block diagram**

This module provides dedicated pad control to general-purpose pads that can be configured as either inputs or outputs. The SIUL2 module provides registers that enable user software to read values from GPIO pads configured as inputs, and write values to GPIO pads configured as outputs:

- When configured as output, you can write to an internal register to control the state driven on the associated output pad.
- When configured as input, you can detect the state of the associated pad by reading the value from an internal register.
- When configured as input and output, the pad value can be read back, which can be used as a method of checking if the written value appeared on the pad.

To assist software development, GPIO data registers can be accessed using various mechanisms. These differing mechanisms allow support for port access or for bit manipulation without the need to use read-modify-write operations:

- Access to two 16-bit ports in one access
- Read/write access to a single bit
- A 16-bit port write with a bit mask, using single 32-bit access.

Sample Reference Manual  
NXP Semiconductors  
Sample Reference Manual  
NXP Semiconductors

**Figure 2. Example of chip-specific information that clarifies content in the same chapter**

### 1.3.2 Chip-specific information that refers to a different chapter

Related chip-specific information may be provided in different chapters of the manual. The following figure shows an example of two such connected pieces of information. In this case, read both before you proceed.



Figure 3. Example of chip-specific information that refers to a different chapter

## 1.4 Register descriptions

Module chapters present register information in the following:

- Memory maps, which contain:
  - An offset from the module's base address
  - The mnemonic and name of each register
  - The width of each register (in bits)
  - The reset value of each register
- Register figures
- Field-description tables
- Associated text

The following figure shows register figure conventions used throughout the manual.

| Access type | Access description         | DITA output            | Effect of Write on Value                                                                                                        | Readback Value   |
|-------------|----------------------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------|------------------|
| RW          | Read/write                 | R<br>W Mnemonic        | Changes to Written Value                                                                                                        | Current Value    |
| RO          | Read-only                  | R<br>W Mnemonic        | No Effect                                                                                                                       | Current Value    |
| RU          | Reserved, unimplemented    | R<br>W Reserved        | No Effect                                                                                                                       | Value Undefined  |
| ROZ         | Reserved, Read-only zero   | R<br>W 0               | No Effect                                                                                                                       | Returns All Zero |
| ROO         | Reserved, Read-only one    | R<br>W 1               | No Effect                                                                                                                       | Returns All Ones |
| WO          | Write-only                 | R<br>W Mnemonic        | Changed to Written Value                                                                                                        | Value Undefined  |
| WOZ         | Reserved, Write-only zero  | R<br>W 0               | Write Value Must Be All 0s.                                                                                                     | Value Undefined  |
| WOO         | Reserved, Write-only one   | R<br>W 1               | Write Value Must Be All 1s.                                                                                                     | Value Undefined  |
| WOC         | Write zero to clear        | R<br>W Mnemonic<br>w0c | If a Bit in the Written Value is a 0, the Corresponding Bit in the Field is Set to 0. Otherwise, the Field Bit is Not Affected. | Current Value    |
| W1C         | Write one to clear         | R<br>W Mnemonic<br>w1c | If a Bit in the Written Value is a 1, the Corresponding Bit in the Field is set to 0. Otherwise, the Field Bit is Not Affected. | Current Value    |
| R2C         | Read to clear              |                        | Value is cleared following the read operation                                                                                   | Current Value    |
| ROWZ        | Read-only, writes zero     | R<br>W 0 Mnemonic      | Write Value Must Be All 0s                                                                                                      | Current Value    |
| ROWO        | Read-only writes one       | R<br>W 1 Mnemonic      | Write Value Must Be All 1s                                                                                                      | Current Value    |
| ROWU        | Read-only writes undefined | R<br>W — Mnemonic      | Writes Operation Undefine                                                                                                       | Current Value    |
| WORZ        | Write-only reads zero      | R<br>W 0 Mnemonic      | Changes to Written Value                                                                                                        | Returns All Zero |
| WORO        | Write-only reads one       | R<br>W 1 Mnemonic      | Changes to Written Value                                                                                                        | Returns All Ones |
| WORU        | Write-only reads undefined | R<br>W — Mnemonic      | Changes to Written Value                                                                                                        | Value Undefined  |

Figure 4. Register figure conventions

**NOTE**

Reset values of reserved locations documented in this manual are subject to change and must not be used for diagnostic purposes.

## 1.5 Conventions

### 1.5.1 Notes and cautions

Specific information is provided as part of notes and cautions throughout this manual.

#### NOTE

Emphasizes information that deserves extra attention.

#### CAUTION

Informs you of situations that could lead to highly undesirable outcomes—such as damage to the chip or irreversible malfunction.

### 1.5.2 Numbering systems

The following suffixes identify different numbering systems:

**Table 1. Numbering systems**

| This suffix | Identifies a                                                                                                                                                      |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| b           | Binary number. For example, the binary equivalent of the number 5 is mentioned as 101b. In some cases, <i>0b</i> is prefixed to binary numbers.                   |
| d           | Decimal number. Decimal numbers are followed by this suffix only when there is a possibility of confusion. In general, decimal numbers are used without a suffix. |
| h           | Hexadecimal number. For example, the hexadecimal equivalent of the number 60 is mentioned as 3Ch. In some cases, <i>0x</i> is prefixed to hexadecimal numbers.    |

### 1.5.3 Typographic notation

The following typographic notations are used throughout this document:

**Table 2. Typographic notation**

| Example                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <i>x</i> and other italicized text | The italicized, lowercase <i>x</i> is used as a placeholder for replaceable numbers. In general, italicized text is used for titles of publications and for emphasis. Additionally, italics could be used for metasymbols in syntax descriptions. Plain lowercase letters are used as placeholders for single letters and numbers.                                                                                                                                                                        |
| code font                          | Fixed-width font (such as Courier) used for code. It is used for a letter, word, or phrase that you want the user to type. For example, "Type Read and press Enter."<br><br>This type of font is also used for instruction mnemonics, directives, symbols, subcommands, parameters, operators, computer-language elements, code listings, commands that appear in running text, and for sample code. Instruction mnemonics and directives in text and tables are mentioned in all caps; for example, BSR. |
| SR[SCM]                            | A mnemonic in square brackets represents the name of a register field. This example refers to the Scaling Mode (SCM) field in the Status Register (SR).                                                                                                                                                                                                                                                                                                                                                   |
| REVNO[6:4], XAD[7:0]               | Numbers in brackets that are separated by a colon represent either: <ul style="list-style-type: none"><li>• A subset of a register's named field</li></ul>                                                                                                                                                                                                                                                                                                                                                |

*Table continues on the next page...*

**Table 2. Typographic notation (continued)**

| Example | Description                                                                                                                                                                                                                                                                                                              |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | <p>For example, REVNO[6:4] refers to bits 6-4 that are part of the COREREV field occupying bits 6-0 of the REVNO register.</p> <ul style="list-style-type: none"> <li>A continuous range of individual signals of a bus</li> </ul> <p>For example, XAD[7:0] refers to signals 7-0 of the XAD bus.</p>                    |
| MOD.REG | <p>A period separates the elements of a hierarchy: subsystem.module.register. For example:</p> <ul style="list-style-type: none"> <li>SWT.TO means that the TO register is located in the SWT module.</li> <li>SMU.XRDC.CR means that the CR register is located in the XRDC module within the SMU subsystem.</li> </ul> |

### 1.5.4 Special terms

The following terms have special meanings.

**Table 3. Special terms**

| Term                   | Meaning                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Asserted               | <p>Refers to the state of a signal as follows:</p> <ul style="list-style-type: none"> <li>An active-high signal is asserted when high (1).</li> <li>An active-low signal is asserted when low (0).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Deasserted             | <p>Refers to the state of a signal as follows:</p> <ul style="list-style-type: none"> <li>An active-high signal is deasserted when low (0).</li> <li>An active-low signal is deasserted when high (1).</li> </ul> <p>In some cases, deasserted signals are described as <i>negated</i>.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Reserved               | <p>Refers to memory space, register, field, or programming setting. Writes to a reserved location can result in unpredictable functionality or behavior. You must:</p> <ul style="list-style-type: none"> <li>Before writing to a location which contain reserved bits user must make sure the write operation will write the reserved bit with value specified as the reset value in NXP reference manual.</li> <li>Consider undefined locations in memory to be reserved as reset value 0 shall be assumed. You might get a BERR(transfer error) response on access to undefined locations in memory.</li> <li>If user reads data from memory area containing reserved bit, the value of reserved bits should be ignored and not used for any functional purposes.</li> </ul> <p style="text-align: center;"><b>NOTE</b></p> <p style="text-align: center;">BootROM could modify the reserved bit values after reset. Please refer to the BootROM settings attachment.</p> |
| Write 1 to clear (w1c) | Refers to the access type of a register field that is used to clear the field by writing the value 1 to it.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Undefined (u)          | Refers to undefined reset values                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

### 1.6 Editorial changes

Each new release of this document includes editorial improvements such as:

- Spelling
- Grammar
- Punctuation
- Voice
- Tense
- Capitalization
- Formatting
- Presentation
- Navigation

# Chapter 2

## Introduction

### 2.1 Overview

MCXA series MCUs expands the MCX Arm® Cortex®-M33 product offerings with multiple high-speed connectivity, operating up to 96 MHz, serial peripherals, timers, analog and low power consumption.

### 2.2 Target applications

This device has following target applications:

- Consumer and industrial IoT
- Industrial Communications
- Smart Metering
- Automation and Control
- Sensors

### 2.3 Block diagram

The following figure shows a top-level organization of the modules within the chip organized by functional category.



Figure 5. Features block diagram

## 2.4 Features

MCXA offers the following features:

- Core
  - Single Cortex-M33 core, operating at 48/96MHz (Barebone, no FPU, no SMID, no Trustzone, no MPU). 48 MHz at Mid Drive mode (1 V), 96 MHz at Standard Drive mode (1.1 V)
  - Nested Vectored Interrupt Controller
  - Clock gating for core processor
  - Multilayer AHB Bus Matrix
- Memories
  - 128 KB Flash array implemented as single array. The smallest programming phrase should be 16 bytes.
    - 128-bit + 9-bit ECC, 8 KB sector size
    - 32 KB User IFR + 8 KB Test IFR
    - 8 KB ECC (with EIM and ERM)
  - Flash Memory Controller
    - Line buffer
    - Prefetch buffer
    - Swap
    - 3 wait states at 96 MHz (SD mode), 1 wait state at 48 MHz (MD mode)
  - Memory Block Checker (MBC)
    - Protect flash read, write and execute permission.
    - Main array granularity is 8 KB
    - IFR0 granularity is 8 KB.
    - IFR1 granularity is 2 KB
  - RAM
    - 4 KB LPCAC to support on-chip Flash caching. 4 KB LPCAC RAM can be used as Code SRAM when LPCAC is disabled.
    - 8 KB Code SRAM
    - 24 KB System SRAM (8 KB with ECC)
  - ROM
    - 16 KB System ROM
- Timers
  - 3 x 32-bit standard general purpose asynchronous timers/counters, which support up to four capture inputs and four compare outputs, PWM mode, and external count input.
  - Low-Power Timer (LPTMR)
  - eFlexPWM (Support 6 PWM outputs)
    - 3 Sub modules supporting 6 complementary outputs
    - 3 fault inputs are supported
  - And/Or/Invert (AOI) module

- implements four events output. Each event output represents a user-programmed combinational Boolean function based on four event inputs.
- The four event inputs are selected from 16 inputs
- Quadrature Decoder (QDC)
- Windowed Watchdog Timer (WWDT)
- Micro Tick Timer (uTick) running from the watchdog oscillator can be used to wake-up the device from sleep and deep-sleep modes. Includes 4 capture registers with pin inputs.
- 42-bit free running OS Timer as continuous time-base for the system.
- Code Watchdog (CDOG) Timer
- Wake Timer
- Communication interfaces
  - 1x LPI2C, 3x LPUART, 2x LPSSPI, 1xI3C
  - USB FS Device with 16 unidirectional endpoints using shared RAM
- Analog
  - 12-bit ADC, up to 16 channels, 4 MSPS
    - high speed channel and 15 low speed channel
    - multiple internal and external triggers
    - Temperature Sensor
  - 2 x Analog Comparator
    - Support LP and HS mode
- Operating characteristics
  - Operating voltage: 1.7 to 3.6 V
  - Temperature range: -40 to 105 C
- Debug
  - Minimal debug – 4 breakpoint and 2 watch point, no ETM
  - Debug mail box for allow tools consistency during power up
  - SWD/JTAG
- Packages
  - 64 LQFP
  - 32 QFN
  - 48 QFN

See the device data sheet for details on packages.

## 2.5 Functional overview

The following table shows the chip modules organized by functional category.

**Table 4. Module functional categories**

| Module category | Description                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Core            | The Arm Cortex-M33 is a member of the Cortex-M Series of processors targeting microcontroller cores focused on cost sensitive, deterministic, and interrupt driven environments. The Cortex-M33 processor is based on the Armv8-M Architecture and ThumbR2 ISA and is upward compatible with the Cortex-M7, M4, M3, M1, and M0/M0+.                                                                                                 |
| System          | <ul style="list-style-type: none"> <li>• Debug Mailbox</li> <li>• AHB Cross-Bar Switch (AXBS) Lite</li> <li>• Enhanced Direct Memory Access (4-channel eDMA)</li> <li>• Wake-Up Unit (WUU)</li> <li>• Peripheral Input Mux (INPUTMUX)</li> <li>• Error Injection Module (EIM)</li> <li>• Error Reporting Module (ERM)</li> <li>• System Power Controller (SPC)</li> <li>• System Controller</li> <li>• RMC (part of CMC)</li> </ul> |
| Memory          | <ul style="list-style-type: none"> <li>• Flash Memory Controller (FMC)</li> <li>• Flash Management Unit (FMU)</li> <li>• ROM-BOOT and ROM-CODE</li> <li>• Static Random Access Memory (SRAM)</li> <li>• AHB Low Power Cache Controller (LPCAC)</li> </ul>                                                                                                                                                                           |
| Clock           | <ul style="list-style-type: none"> <li>• VBAT Wrapper <ul style="list-style-type: none"> <li>— Free Running Oscillator - 16 K (FRO_16K)</li> </ul> </li> <li>• System Clock Generator (SCG) <ul style="list-style-type: none"> <li>— Crystal Oscillator - System (OSC_SYS)</li> <li>— Free Running Oscillator - 192 M (FRO_192M)</li> <li>— Free Running Oscillator - 12 M (FRO_12M)</li> </ul> </li> </ul>                         |
| Security        | <ul style="list-style-type: none"> <li>• Cyclic Redundancy Check (CRC)</li> <li>• Code Watchdog</li> <li>• Glikey</li> <li>• Memory Block Checker (MBC)</li> </ul>                                                                                                                                                                                                                                                                  |
| Timer           | <ul style="list-style-type: none"> <li>• eFlexPWM</li> <li>• Quadrature Decoder (ENC)</li> <li>• Micro-Tick (UTICK) Timer</li> </ul>                                                                                                                                                                                                                                                                                                |

*Table continues on the next page...*

**Table 4. Module functional categories (continued)**

| Module category               | Description                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                               | <ul style="list-style-type: none"> <li>• OS Event Timer (OSTIMER)</li> <li>• Low-power Timer (LPTMR)</li> <li>• Standard Counter/Timer (CTIMER)</li> <li>• Windowed Watchdog Timer (WWDT)</li> <li>• Frequency Measurement (FREQME)</li> <li>• Wake Timer</li> </ul>                                                                                 |
| Communication                 | <ul style="list-style-type: none"> <li>• Improved Inter-Integrated Circuit (I3C)</li> <li>• Universal Serial Bus - Full Speed (USBFS) and Transceiver</li> <li>• USB FS Physical Layer Interface (USBFS PHY)</li> <li>• Low-Power UART (LPUART)</li> <li>• Low-Power Serial Peripheral Interface (LPSPI)</li> <li>• Low-Power I2C (LPI2C)</li> </ul> |
| Human Machine Interface (HMI) | <ul style="list-style-type: none"> <li>• General Purpose Input/Output (GPIO)</li> <li>• Port Control (PORT)</li> </ul>                                                                                                                                                                                                                               |
| Analog                        | <ul style="list-style-type: none"> <li>• 16-bit Analog-to-Digital Converter (ADC) with 4 Msps conversion rate</li> <li>• Low Power analog Comparator (LPCMP)</li> </ul>                                                                                                                                                                              |

## 2.5.1 Core

The following core modules are available on this chip.

**Table 5. Core modules**

| Module                                      | Description                                                                                                                                                                                                 |
|---------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU                                         | Is an Arm Cortex-M33 processor that runs at a frequency of up to 96 MHz.                                                                                                                                    |
| Nested Vectored Interrupt Controller (NVIC) | The Armv8M exception model and Nested-Vectored Interrupt Controller (NVIC) implement a relocatable vector table supporting external interrupts, a single non-maskable interrupt (NMI), and priority levels. |
| System Tick Timer (SysTick)                 | See the Armv8M Architecture Reference Manual for more information about this system timer.                                                                                                                  |

## 2.5.2 Clock

The following clock modules are available on this chip.

**Table 6. Clock sources**

| Module                                       | Description                                                                                                                                                                          |
|----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Free Running Oscillator - 16 K (FRO_16K)     | Is an ultra-low power internal 16.384 kHz clock source. It is functional down to VBAT mode. The FRO_16K is trimmed to +/- 6% accuracy over the entire voltage and temperature range. |
| System Clock Generator (SCG)                 | Provides the user with access to the configuration control registers for the system level clock sources.                                                                             |
| Crystal Oscillator - System (OSC_SYS)        | Generates, in conjunction with an external crystal or resonator, a reference clock for the chip.                                                                                     |
| Free Running Oscillator - 192 MHz (FRO_192M) | The free running oscillator can generate 192 MHz for use by the chip.                                                                                                                |
| Free Running Oscillator - 12 MHz (FRO12M)    | Is an internal clock source that generates a 12 MHz frequency for use by the chip.                                                                                                   |

### 2.5.3 Communication

The following communication modules are available on this chip.

**Table 7. Communication modules**

| Module                                                     | Description                                                                                                                                                                                             |
|------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Low Power Inter-Integrated Circuit (LPI2C)                 | Allows communication between a number of devices. Also supports the System Management Bus (SMBus) Specification, version 2.                                                                             |
| Improved Inter-Integrated Circuit (I3C)                    | Is an extension of the I2C bus protocol supporting higher speeds.                                                                                                                                       |
| Low Power Serial Peripheral Interface (LPSPI)              | Synchronous serial bus for communication to an external device.                                                                                                                                         |
| Low Power Universal Asynchronous Receive/Transmit (LPUART) | Asynchronous serial bus communication interface with programmable 8- or 9-bit data format.                                                                                                              |
| Universal Serial Bus Full Speed Device Controller (USBFS)  | In Device mode, the USB FS subsystem working together with the SCG module can use the FIRC to generate a 48 MHz USB controller clock tuned using the incoming Host USB data for crystal-less operation. |

### 2.5.4 Debug

The following debug modules are available on this chip.

**Table 8. Debug modules**

| Module                          | Description                                                                                                                                                                              |
|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Data Watchpoint and Trace (DWT) | Is a generic name for modules that allow debug access of the Cortex-M33. The DWT comprises of the Debug Watchpoint and Trace (DWT) module and the Flash Patch and Breakpoint (FPB) unit. |
| Debug Access Port (DAP)         | Enables real-time access to the chip registers from an external debugger without halting the processor cores.                                                                            |

*Table continues on the next page...*

**Table 8. Debug modules (continued)**

| Module                            | Description                                                                                                                              |
|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Instruction Trace Macrocell (ITM) | Provides a memory-mapped register interface that applications can use to write logging or event words for profiling software.            |
| Joint Test Action Group (JTAG)    | Implements serial communication protocol for communication with the Test Access Port (TAP).                                              |
| Serial Wire Debug (SWD)           | Is a serial communication interface used for debugging devices with multiple cores while only requiring a single external interface.     |
| Trace Port Interface Unit (TPIU)  | Acts as a bridge between the on-chip trace data from the modules such as the ITM, which have separate system IDs, to the external world. |

## 2.5.5 Memory

The following memory modules are available on this chip.

**Table 9. Memory modules**

| Module                                 | Description                                                                                                     |
|----------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| Flash Memory Controller (FMC)          | Is a programmable flash memory — non-volatile flash memory that can store executable program code or data.      |
| Flash Management Unit (FMU)            | Manages the interface between the chip and the on-chip flash memory.                                            |
| Static Random Access Memory (SRAM)     | Internal system SRAM memory. Each individual block of SRAM can be configured to be retained in low-power modes. |
| AHB Low Power Cache Controller (LPCAC) | Is a processor-local level 1 (L1) bus cache controller for use with cores using AMBA-AHB input/output buses.    |

## 2.5.6 System

The following system modules are available on this chip.

**Table 10. System modules**

| Module                     | Description                                                                                                                                                                                   |
|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Debug mailbox              | Supports Arm Serial Wire Debug mode.                                                                                                                                                          |
| Peripheral Bridge(PBRIDGE) | Converts an AMBA AHB interface to a peripheral interface that allows the Peripheral Bridge (PBRIDGE) controller to interface to multiple peripherals. This device has two peripheral bridges. |
| System Controller (SYSCON) | Provides controls and configurations of the system and peripherals for the multiple functions.                                                                                                |
| Core Mode Controller (CMC) | The CMC provides control and protection on entry and exit to each power mode, control for the System Power Controller (SPC), and reset entry and exit for the complete device.                |

*Table continues on the next page...*

**Table 10. System modules (continued)**

| Module                                   | Description                                                                                                                                                                     |
|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Enhanced Direct Memory Access (eDMA)     | Performs source/destination address calculations and data-movement operations.<br>Capable of performing complex data transfers with minimal intervention from a host processor. |
| Wake-up Unit (WUU)                       | Allows selection of external pins and internal modules as interrupt wake-up sources from Deep Sleep and Power Down modes.                                                       |
| Peripheral Input Multiplexing (INPUTMUX) | Allows the trigger output of one peripheral to be connected to the trigger input of a second peripheral.                                                                        |
| Error Injection Module (EIM)             | Provides a method for diagnostic coverage of internal memories (for example, system RAM, cache RAMs, and peripheral memories).                                                  |
| Error Reporting Module (ERM)             | Provides information and optional interrupt notification on memory error events associated with Error correction code (ECC) and parity.                                         |
| System Power Controller (SPC)            | Provides control over the operation and configuration of the system power generation modules to optimize power consumption for the level of functionality needed.               |
| Low Drop Out Regulator - Core (LDO_CORE) | A voltage regulator for generating the core voltage for the chip.                                                                                                               |
| RAM_RET_LDO                              | A voltage regulator for generating the voltage for SRAM retention.                                                                                                              |

### 2.5.7 Security

The following security modules are available on this chip.

**Table 11. Security modules**

| Module                        | Description                                                                                                                                                 |
|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Cyclic Redundancy Check (CRC) | Provides error detection for all single, double, and many multi-bit errors.                                                                                 |
| GLIKEY                        | It provides a mechanism to safely access security-sensitive registers.                                                                                      |
| Code Watch Dog                | Helps protect the integrity of software by detecting unexpected changes (faults) in the code execution flow.                                                |
| Memory Block Checker (MBC)    | Provides domain-based access control for all system bus references targeted to on-chip internal memories and slave peripherals. It's a part of TRDC module. |

### 2.5.8 Timer

The following timer modules are available on this chip.

**Table 12. Timer modules**

| Module                          | Description                                                                                                                                           |
|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| FlexPWM                         | Generates various switching patterns, including highly sophisticated waveforms.<br>Controls different Switched Mode Power Supplies (SMPS) topologies. |
| Wake Timer                      | Provides time keeping and calendaring functions and additionally provides protection against spurious memory/register updates and battery operation.  |
| Quadrature Decoder              | Interfaces to position/speed sensors that are used in industrial motor control applications.                                                          |
| Micro-Tick (UTICK) Timer        | Is a 31-bit timer that provides a fixed time interval between interrupts.                                                                             |
| OS Event Timer (OSTIMER)        | Is a 42-bit Gray code counter.                                                                                                                        |
| Low-power Timer (LPTMR)         | Is a 16-bit timer or pulse counter with compare feature.                                                                                              |
| Standard Counter/Timer (CTimer) | Each Counter/timer is designed to count cycles of the CTIMER function clock.                                                                          |
| Windowed Watchdog Timer (WWDT)  | Helps reset or interrupt an erroneous microcontroller within a programmable time.                                                                     |
| Frequency Measurement           | Provides high-accuracy frequency measurement function for on-chip and off-chip clocks.                                                                |

### 2.5.9 Human Machine Interface (HMI)

The following HMI modules are available on this chip.

**Table 13. HMI modules**

| Module                              | Description                                                 |
|-------------------------------------|-------------------------------------------------------------|
| General Purpose Input/Output (GPIO) | All GPIO pins support interrupt and DMA request generation. |
| Port Control (PORT)                 | Provides support for pad control functions.                 |

### 2.5.10 Analog

The following analog modules are available on this chip.

**Table 14. Analog modules**

| Module                            | Description                                                                                              |
|-----------------------------------|----------------------------------------------------------------------------------------------------------|
| Analog-to-Digital Converter (ADC) | Successive approximation ADC designed for operation within an integrated microcontroller system-on-chip. |
| Low Power Comparator (LPCMP)      | Provides a circuit for comparing two analog input voltages.                                              |

# Chapter 3

## Core Overview

### 3.1 Introduction

This section covers the core modules included in this chip.

### 3.2 Cortex-M33 Code and System buses

This device has one Arm Cortex-M33 processor core, without TrustZone-M, Floating Point Unit (FPU), and Memory Protection Unit (MPU).

The core implements a modified Harvard memory architecture using two 32-bit bus interfaces: the Code and System buses. The bus interfaces are activated by address range and can include both instruction fetches and operand data references on a given bus port.(A traditional Harvard architecture strictly separates instruction fetches and operand data references onto specific bus ports regardless of access address.) The Code bus is typically used for instruction fetching and data accesses of PC-relative data, while the system bus is typically used for operand data references to the on- and off-chip memories and peripheral accesses. The bus structure fully supports concurrent instruction fetch and data accesses, but the Cortex-M33 implementations can generate both types of references on each bus.

---

#### NOTE

It is recommended that performance critical code be located such that it fetches from the Code bus interface as defined by addresses < 0x2000\_0000.

---

#### 3.2.1 Code Bus access

Code Bus accesses are routed to the Code Cache Controller; code bus of the core goes to LPCAC. This controller then processes the cacheable accesses as needed, while bypassing the non-cacheable accesses or forwarding the cache write-through and cache miss accesses to the downstream memories through the master port of this cache controller.

#### 3.2.2 System bus access

All System bus accesses are routed to the target address in destination memories through multilayer AHB matrix slave port.

#### 3.2.3 Access control

All core Code and System Bus accesses are checked by the core access control logic. All requests that miss or bypass the cache are checked by downstream secure AHB bus logic. The caches include protection control signals (HPROT[3:0]) and processing domain bits as part of the tags. If a fetch address hits the cache but the protection control and/or domain bits are different, the cache controller forces a miss with the allocate location the same as the address hit location in the cache. This policy allows all the downstream checks to take place, and this new miss is loaded in the cache with the updated protection control and domain bits overwriting the line with the same address. This keeps the cache coherent while always checking accesses that need to see the downstream checks.

## 3.3 Nested Vectored Interrupt Controller (NVIC)

### 3.3.1 Interrupt priority levels

This device supports 8 priority levels for interrupts. Therefore, in the NVIC each source in the IPR registers contains 3 bits. For example, IPR0 is shown below:

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

### 3.3.2 Non-Maskable Interrupt (NMI) configuration

The Non-Maskable Interrupt (NMI) enable bit and source selection bits are implemented for each core in SYSCON register.

### 3.3.3 Interrupt channel assignments

The interrupt source assignments are defined in the following table.

- Vector number — the value stored on the stack when an interrupt is serviced.
- IRQ number — non-core interrupt source count, which is the vector number minus 16.

The IRQ number is used within Arm's NVIC documentation.

See the attached NVIC\_Configuration spreadsheet for the NVIC interrupt assignments.

## 3.4 System memory map

See the attached Memory Map spreadsheet (Overview tab) for the chip's high-level memory map.

## 3.5 Peripheral Bridge

The Peripheral Bridge (PBRG) is the portion of the bus fabric that connects the peripherals to the processor elements. Each peripheral has a base address where the processor elements can access them.

### 3.5.1 Peripheral Bridge (PBRIDGE0-1) memory maps

See the attached Memory Map spreadsheet for PBRIDGE0, PBRIDGE1, and Fast Peripherals (Peripheral Memory Map tab) peripheral memory mapping on this device.

# Chapter 4

## Bus and Memory Architecture

### 4.1 Bus and Memory architecture

This chapter provides an overview of system bus and memory architecture of this device. The memory architecture supports a wide range of target applications and maximizes performance while maintaining low power consumption. The memory system of the device includes SRAM, ROM, internal flash, and external memory.

The following figure shows the system bus diagram of this chip.



Figure 6. Bus matrix block diagram

## 4.2 System bus priority and arbitration

The multilayer AHB bus matrix allows for concurrent accesses when two masters are attempting to access to different slave ports. If two masters attempt an access to the same slave port at the same time then arbitration is required.

The programmable priorities for each of the master ports can be configured through AHBMATPRIO register in SYSCON. Masters are assigned a priority value between 0 and 3 with 3 being the highest priority. If two ports have the same priority, then the lowest port number is given priority.

There are some master ports that are shared between two masters. Where the port is shared, only one of the masters can have an active access at a time. The priority between two masters sharing a port uses a PARK\_ON\_LAST arbitration scheme. This means

that the last of the two masters to use the port is given priority. Before either of the masters has used the port, there is a default priority scheme that determines which master is prioritized for the first access. The table below lists the master or masters for each of the ports.

**Table 16. AHB Matrix priority control register**

| Bit   | Master name             | Master AHB ID | Reset value |
|-------|-------------------------|---------------|-------------|
| 1:0   | CM33 Code Bus           | 0x0           | 0x0         |
| 3:2   | CM33 System Bus         | 0x1           | 0x0         |
| 5:4   | Reserved                | 0x2           | 0x0         |
| 7:6   | Reserved                | 0x3           | 0x0         |
| 9:8   | eDMA Controller AHB Bus | 0x5           | 0x0         |
| 11:10 | Reserved                | 0x4           | 0x0         |
| 13:12 | Reserved                | 0xC           | 0x0         |
| 15:14 | Reserved                | 0x7           | 0x0         |
| 17:16 | Reserved                | 0x8           | 0x0         |
| 19:18 | Reserved                | 0x9           | 0x0         |
| 21:20 | Reserved                | 0xA           | 0x0         |
| 23:22 | Reserved                | 0xB           | 0x0         |
| 25:24 | USB FS AHB Bus          | 0x6           | 0x0         |
| 27:26 | Reserved                | 0xD           | 0x0         |
| 29:28 | Reserved                | 0xE           | 0x0         |
| 31:30 | Reserved                | Reserved      | 0x0         |

#### AHB to APB Bridge

The bridge connects legacy LPC APB/VPB interface peripherals.

#### AIPS bridge

The bridge connects IPS/APB interface peripherals.

### 4.3 SRAM configuration

SRAM is divided into Code TCM and System TCM.

CTCM: Mapped to CM33 code bus space

- RAM X0: 8 KB 32-bit RAM
- RAM X1: 4 KB 32-bit RAM

RAMX1 can only be used as code RAM when LPCAC is disabled.

STCM: Mapped to CM33 system bus space

- RAM A0: 8 KB 32+7-bit ECC RAM
- RAM A1: 16 KB 32bit RAM

### SRAM permission control

This chip implements a logic between RAM controller and AHB Slave port to control SRAM write permission. SRAM write permission control registers is implemented in SRAM\_XEN[3:0] bits of the SYSCON as below

0: disable, default value

1: enable

- SRAM\_XEN[0] controls RAM X0 8KB, offset 0x0~0x1FFF
- SRAM\_XEN[1] controls RAM X1 4KB, offset 0x2000~above
- SRAM\_XEN[2] controls RAM A0 8KB, offset 0x0~0x1FFF
- SRAM\_XEN[3] controls RAM A1 16KB, offset 0x2000~above
- A lock bit is also implemented in SRAM\_XEN. Once locked, the register can't be programmed unless there is a reset.

GLIKEY is used to protect the access of SRAM\_XEN register.

The figure below shows the SRAM configuration on this chip.



Figure 7. SRAM configuration

#### 4.3.1 SRAM ECC

RAM A0 supports single-bit correction, and two bits detection ECC on every 32-bit aligned field. ECC supports byte and half-word operation. ECC can be disabled via SYSCON register.

#### 4.3.2 RAM ECC Error

The Error Reporting Module (ERM) provides information and optional interrupt notification on SRAM error events associated with ECC. The syndrome and error address information is captured along with error event in ERM registers.

The Error Injection Module (EIM) can be used to induce artificial errors in the RAM ECC. EIM can inject single-bit and multi-bit inversions on data. Injecting faults on memory accesses can be used to exercise the SEC-DED ECC function of the related system.

## 4.4 Read Only Memory (ROM)

The internal ROM memory is used to store the boot code and time-critical software library routines. After a reset, the Cortex-M33 processor starts its code execution from this memory.

## 4.5 Flash subsystem

This device embeds 128 KB of single-array flash configuration. The Flash subsystem includes MBC, FMC and FMU (MSF1). FMC implements a 128-bit entry buffer and a 128-bit prefetch buffer. The control register for prefetch buffer is implemented in the System Controller (SYSCON) chapter.

The following figure shows the high-level block diagram of the on-chip flash.



### Flash array configuration

This chip has one 128 KB flash array, which includes 128 KB main array, 32 KB IFR0, and 8KB IFR1. The sector1 to sector3 IFR0 are used to store flash loader, which is programmed by NXP. There are boot options provided for user in sector0 IFR0, which must be programmed by user. There is IFR0 table to define the details of boot options. See Boot chapter for details.

### Flash ECC

Flash array supports ECC on every 128 bits. This chip implements a register in the SYSCON to disable Flash ECC error to generate bus fault, and use interrupt to handle ECC error.

### Flash swap

FMC supports the swap function. The single flash array is divided to four regions. Two swappable regions and two static regions. When swap enables, swappable region 1 is mapped to logic address 0. Below is an example: Considering flash size is 128 KB:

- Swappable Region 0: flash physical address 0 ~ Upper limit
- Static Region 0: Upper limit ~ 64 KB
- Swappable Region 1: 64 KB ~ 64 KB + Upper limit
- Static Region 1: 64 KB + Upper limit ~ Flash End

### SWAP enabled

- Map Swappable Region 1 to logic address starting at 0x0 ~ upper limit

- Static Region 0 logic address unchanged
- Map Swappable Region 0 to logic address starting at 0x10000 ~ 0x10000 + upper limit
- Static Region 1 unchanged

Swap granularity is 8 KB. The chip supports 128 KB flash array.

#### Flash performance

- 96 MHz SD mode, 3 wait states
- 48 MHz, MD mode, 1 wait state

### 4.5.1 Low-Power Cache Controller (LPCAC)

This chip implements 4 KB cache between CM33 code bus and AHB Matrix.

### 4.5.2 Flash memory controller

The Flash Memory Controller (FMC) manages accesses performed by the bus masters of the system to the flash memory. The FMC accelerates flash memory transfers to allow program code execution at higher clock frequency than flash memory.

The FMC provides two separate mechanisms for accelerating read operations to the flash memory:

- A single-entry 128-bit buffer, which can store previously accessed flash memory
- A 128-bit prefetch buffer, which can prefetch the next 128-bit flash memory location

---

#### NOTE

The FMC has no visibility into flash memory erase and program cycles because the Flash Memory module manages them directly.

---

#### 4.5.2.1 Single entry buffer

The width of the bus between the FMC and the flash blocks is 128-bit. A single read of the flash will return an entire bus width worth of data. Because the flash bus is wider than the master's bus, the Single-Entry Buffer is used to store data from the last flash read for quick access times on subsequent reads if the buffer is hit.

The FMC provides invalidation control for the Single-Entry Buffer.

#### 4.5.2.2 Prefetch buffer

When speculative reads are enabled, the FMC immediately requests the next sequential address after a read completes. The next 128-bit memory location is read and placed in the Prefetch Buffer. The speculative prefetch mechanism improves performance by reducing or even eliminating wait states when accessing sequential code and/or data.

Speculative prefetching is programmable for each bank of memory. The FMC provides invalidation control for the Prefetch Buffer.

# Chapter 5

## Low Power Cache Controller (LPCAC)

### 5.1 Chip-specific LPCAC information

Table 17. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | LPCAC          | <a href="#">LPCAC</a>               |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

NOTE

See [LPCAC Control \(LPCAC\\_CTRL\)](#).

#### 5.1.1 Module instances

This device has one instance of the LPCAC module.

#### 5.1.2 LPCAC cacheable memory range

The LPCAC module has no registers. All configuration for the LPCAC module is handled through the LPCAC\_CTRL register of SYSCON. The 4 KB LPCAC is connected to the Code bus of the primary CM33 core. Contents of this cache are only visible to the CM33 core. The cacheable memory range are shown in table below. For details, see the attached System memory map.

Table 18. LPCAC cacheable memory range

| Start Address | End Address | Description   | Size   | Cached |
|---------------|-------------|---------------|--------|--------|
| 0000_0000     | 0001_FFFF   | Program Flash | 128 KB | LPCAC  |

## 5.2 Overview

LPCAC provides low-latency access to instructions or data. This decouples processor performance from system memory performance, increasing bus availability for other modules and improving system performance.

LPCAC has a 32-bit datapath AMBA-AHB input bus and a 32-bit datapath AMBA-AHB output bus.

### 5.2.1 Block diagram



Figure 8. Block diagram

### 5.2.2 Features

LPCAC supports the following features:

- Nonblocking and write-through cache mode
- 4 KB total cache size
- Cache organization as an 8-way, 2-set-associative design based on 256-byte superpages
- Each way or superpage contains up to 16 sequential 16-byte pages
- Cache supports optional odd parity with one bit of odd parity per byte of cache data.
  - Cache can recover and scrub data parity errors by forcing miss on parity error and reloading data

## 5.3 Functional description

This section provides further information on the LPCAC module operation.

A reset signal clears and enables this module.

LPCAC examines every valid AHB input access. If the access hits the cache memory region and the cache is enabled, the access goes to the cache portion of the module. If the access is not cacheable, the access is passed directly to the AHB output bus.

The LPCAC cache has a 256-byte line subdivided into 16 16-byte sublines:

- Cache read accesses that are cache misses perform an aligned 16-byte subline-size burst cache read miss to the module's AHB output bus. Then the cache loads the needed data in the cache's data storage. The cache miss uses a 4-beat (32 bits per beat), wrapped burst bus access to fetch the cache miss data.
- Cache read accesses that are cache hits return the desired read data from the cache.
- Cache write accesses that are cache misses perform the desired write operation only to the module's AHB output bus (for write-through mode accesses, LPCAC has a no allocation on write-miss policy).

- Cache write accesses that are cache hits perform the desired write operation to the cache and the module's AHB output bus.
- LPCAC has a one entry write buffer. When enabled, cache write accesses with a bufferable attribute use the buffer. When enabled and available, the buffer allows write from the processor to receive an immediate (zero wait state) bus termination.

### 5.3.1 Cache functional description

The LPCAC cache is an 8-way, 2-set-associative, 256-byte per line write-through design. It supports a total cache capacity of 4 KB for a 32-bit wide cache miss datapath.

#### 5.3.1.1 Cache controls

This module has controls to enable, disable, and clear the cache.

The cache control inputs are as follows:

- `clr_lpcac`: clear lpcac
- `dis_lpcac`: disable lpcac
- `dis_lpcac_wtbf`: disable write buffer
- `lim_lpcac_wtbf`: limit write buffer
- `frc_no_alloc`: force no allocation
- `parity_miss_en`: enable parity, miss on parity error
- `parity_fault_en`: enable parity error reporting

See chip-specific section for details on how these signals are connected or controlled on a given device.

### 5.3.2 Clocks

The core clock domain defines the module's clock domain.

### 5.3.3 Reset

A reset signal clears and enables this module. See the chip-integration information for the resets that affect LPCAC.

### 5.3.4 Interrupts

This module has no interrupts.

## 5.4 Signal descriptions

This module has no external signals.

## 5.5 Memory regions and input control description

### 5.5.1 Memory regions

LPCAC decodes cacheable address regions. The cache memory region may be composed of one or more disjointed memory regions and the total size may be larger than the cache storage.

Any address not in the cacheable memory regions is in the pass-through memory region. All accesses to the pass-through memory regions are non-cacheable. For all accesses to the cacheable memory regions, the access is cacheable if the attributes of the access indicate that it can be cached, else the access is non-cacheable.

See the System Memory Map for cache memory range information.

### 5.5.2 Input controls

The LPCAC does not have a module-resident programming model. An external block supplies the needed LPCAC control inputs.

**Table 19. Control inputs for LPCAC**

| Function             | Control input   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| clear lpcac          | clr_lpcac       | One cycle active-high pulse clears the lpcac.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| disable lpcac        | dis_lpcac       | <ul style="list-style-type: none"> <li>• 0 = lpcac enabled (reset configuration)</li> <li>• 1 = lpcac disabled, all cacheable accesses pass from LPCAC input to output bus</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| disable write buffer | dis_lpcac_wtbf  | <ul style="list-style-type: none"> <li>• 0 = write buffer enabled</li> <li>• 1 = write buffer disabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| limit write buffer   | lim_lpcac_wtbf  | <ul style="list-style-type: none"> <li>• 0 = If write buffer is enabled, buffer all writes to spaces that are bufferable</li> <li>• 1 = If write buffer is enabled, buffer all writes to spaces that are both bufferable and cacheable</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| force no allocation  | frc_no_alloc    | <p>When frc_no_alloc is asserted and the cache is enabled, all accesses to the cache search the cache. If they hit a valid entry that was loaded before frc_no_alloc was asserted, they operate normally. That is, read hits return cache data without going through the cache and write hits update cache data and write through the cache. If they miss, they bypass the cache (that is, even though a read access is to a cacheable space, it does not allocate on a cache miss).</p> <p>This control input is useful for debug. Say there is a software breakpoint, halting the processor. Then, using the debug port, cacheable memory as well as other address spaces are accessed. These debug accesses go through the processor, through the cache, and to the rest of the system. The idea is during the debug accesses the cache is placed on frc_no_alloc mode. In this way, debug access through the core and then through the cache do not disturb the state of the cache. Before restarting the processor, frc_no_alloc mode is negated. When the processor restarts, the cache state is the same or at least very similar as the cache state when the breakpoint was hit.</p> <ul style="list-style-type: none"> <li>• 0 = normal allocation on cache miss</li> <li>• 1 = no allocation on cache miss</li> </ul> |
| parity miss enable   | parity_miss_en  | <p>Enables miss on parity to scrub parity error and to reload the data line that had the parity error.</p> <ul style="list-style-type: none"> <li>• 0 = do not take a miss on a parity error</li> <li>• 1 = force a miss on a parity error</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| parity enable        | parity_fault_en | <p>Enables and disables parity error report.</p> <ul style="list-style-type: none"> <li>• 0 = disable</li> <li>• 1 = enable</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

# Chapter 6

## Flash Memory Module (FMU)

### 6.1 Chip-specific FMU information

Table 20. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | FMU            | <a href="#">FMU</a>                 |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 6.1.1 Module instances

This device contains one instance of the FMU module, FMU0.

#### 6.1.2 FCTRL[RWSC] configuration

The configuration of Read Wait-State Control (RWSC) field of Flash Control Register (FCTRL) is shown in below table.

Table 21. FCTRL[RWSC] configuration in different run modes and speed

| SD Mode (VDD_CORE = 1.1V) | MD Mode (VDD_CORE = 1.0V) | RWSC            |
|---------------------------|---------------------------|-----------------|
| 96 MHz                    |                           | 0010b           |
| 48 MHz, 64 MHz            | 32 MHz, 48 MHz            | 0001b (default) |
| <=32 MHz                  | <=24MHz                   | 0000b           |

## 6.2 Overview

The flash module includes the following accessible memory regions:

- Program flash memory for vector space and code store
- Separate flash memory for parameter store

Flash memory is ideal for single-supply applications, permitting in-the-field erase and reprogramming operations without the need for any external high voltage power sources.

The flash module includes a command controller that executes commands to modify flash memory contents. An erased bit reads '1' and a programmed bit reads '0'. The programming operation is unidirectional; it can only move bits from the '1' state (erased) to the '0' state (programmed). Only the erase operation restores bits from '0' to '1'; bits cannot be programmed from a '0' to a '1'.

#### CAUTION

A flash memory location must be in the erased state before being programmed. Cumulative programming of bits (back-to-back program operations without an intervening erase) within a flash phrase or page is not allowed.

Re-programming of existing 0s to 0 is not allowed as this overstresses the device.

The standard shipping condition for flash memory is erased. Data loss over time may occur due to degradation of the erased ('1') states and/or programmed ('0') states. Therefore, it is recommended that flash memory be re-erased immediately prior to factory programming to ensure that the full data retention capability is achieved.

### 6.2.1 Block diagram

The block diagram of the flash module is shown in the following figure.



### 6.2.2 Features

The flash memory module provides the following features:

- Sector size of 8 Kbytes
- Single-bit error correction and double-bit error detection for each flash or IFR phrase
- Signature generation for flash contents
- Command-based flash program, erase, and verify operations
- Internal high-voltage supply generator for flash program and erase operations
- Optional interrupt generation upon flash command completion
- Optional interrupt generation upon double-bit error detection during flash reads from the FMC

**NOTE**

See the chip configuration details for the exact amount of flash memory available.

## 6.3 Functional description

The following sections describe functional details of the flash module.

### 6.3.1 Operations

Operations are typically used to modify flash memory contents. The next sections describe:

- Command write sequence used to set flash command parameters and launch execution
- Available flash commands
- Commands impacted by Block Checker and FMC access protection

#### 6.3.1.1 Command write sequence

Flash commands are accomplished using a command write sequence illustrated in [Figure 10](#). The command controller monitors the transaction protection level on writes during the command write sequence, performs various checks on the command (FCCOB) content, and continues with command execution if all requirements are fulfilled.

Before launching a command, the ACCERR, PVIOL, and CMDABT flags in the FSTAT register must be zero and the CCIF flag must be one to verify that any previous command has completed. The FAIL flag in the FSTAT register is cleared by the command controller when a command is launched unless the FAIL flag was set during initialization due to FMU parameters not being loaded from IFR1. If CCIF is clear, the previous command execution is still active, a new command write sequence cannot be started, and all writes to the FCCOB registers are ignored.

While a flash command is executing, attempts to write to FCTRL[LSACTIVE] are ignored.

### 6.3.1.1.1 Load the FCCOB Registers

The user must load the FCCOB registers with all parameters required by the specific flash command. The contents of any FCCOB register not used by the specific flash command are ignored except for FCCOB1 (command options) where undefined bits should be cleared. The individual registers that make up the FCCOB data set can be written in any order. All writes to the FCCOB registers in a command write sequence must occur at the same transaction protection level. Any write to the FCCOB registers that violates this rule will be ignored.

Addresses loaded into FCCOB registers assume the flash and IFR spaces start at 0000\_0000h.

### 6.3.1.1.2 Launch the Command by Clearing CCIF

Once all relevant command parameters have been loaded, the user launches the command by clearing the FSTAT[CCIF] bit by writing a '1' to it. The write to clear CCIF must occur at the same transaction protection level as the writes used to load the FCCOB registers. Any write to clear CCIF that violates this rule will be ignored. The CCIF flag remains clear until the flash command completes.

The FSTAT register contains a blocking mechanism which prevents a new flash command from launching (unable to clear CCIF) if the previous command resulted in the setting of an access error (ACCERR), protection violation (PVIOL), or active command abort flag (CMDABT). In error scenarios, two writes to FSTAT are required to initiate the next command: the first write to clear these flags, the second write to clear CCIF. The write to clear these flags can occur at any transaction protection level.

### 6.3.1.1.3 Command Execution and Error Reporting

Flash command processing contains the following steps:

1. The command controller performs a series of parameter checks, if applicable, which are unique to each command. If the parameter check fails, the FSTAT[ACCERR] flag is set. ACCERR reports invalid instruction codes or options, out of bounds or misaligned addresses, or missing FMU parameters. In the case FMU parameters were not loaded from IFR1 during initialization, the ACCERR flag sets and the FSTAT[FAIL] flag remains set. Command processing never proceeds to execution when the parameter check fails. Instead, command processing is terminated after setting the FSTAT[CCIF] flag. Note that for program and erase operations, PEWEN will not set if FMU parameters were not loaded and PERDY will not set if program or erase related writes to flash or IFR space violate command requirements.
2. If necessary, the command controller performs a protection check to see if the command is allowed to execute on the requested memory space. If the protection check fails, the FSTAT[PVIOL] flag is set. Command processing never proceeds to execution when the protection check fails. Instead, command processing is terminated after setting the FSTAT[CCIF] flag.
3. If the parameter and protection checks pass, the command proceeds to execution. Run-time errors, such as failure to verify, may occur during the execution phase and are reported in the FAIL flag. A flash command may have access errors, protection violations, and run-time errors, but the run-time errors are not seen until all access errors and protection violations have been corrected.
4. If FCTRL[ABTREQ] sets during command execution, the operation will abort with the FSTAT[CMDABT] flag set.
5. Command execution results, if applicable, are reported back to the user via the FCCOB registers.
6. The command controller sets FSTAT[CCIF] signifying that the command has completed.

**CAUTION**

If the FAIL flag is set along with ACCERR, FMU parameters were not loaded from IFR1 during initialization. In this case, it is recommended that the flash module be reinitialized. If the issue persists, flash commands will continue to set the ACCERR and FAIL flags.

The flow for a generic command write sequence is illustrated in the following figure.



Figure 10. Generic Flash Command Write Sequence Flowchart  
MCX A153, A152, A143, A142 Reference Manual, Rev. 4, 01/2024

#### 6.3.1.1.4 Aborting a Command Write Sequence or Command Operation

FSTAT[CMDP] sets at the start of a command write sequence, typically by writing to one of the FCCOB registers. With CMDP set, setting the FCTRL[ABTREQ] bit allows a user to abort a command write sequence and take control over a new command write sequence. The ABTREQ bit can only be set by a user with the same domain ID as indicated by FSTAT[CMDDID] and at the same or higher security/privilege protection level when compared to FSTAT[CMDPRT], the current owner of the command write sequence. While ABTREQ is set, CCIF cannot be cleared to launch a command.

If FSTAT[CCIF] is high when ABTREQ is set, the command write sequence will abort and ownership transferred to the user setting the ABTREQ bit. The FSTAT[CWSABT] flag will set and the CMDPRT field will be updated based on the write transaction that set the ABTREQ bit. The ABTREQ bit will then be cleared automatically.

If CCIF is low when ABTREQ is set, the command controller will abort execution of the current command operation, set FSTAT[CMDABT], and set CCIF. The CMDPRT field will be updated based on the write transaction that set the ABTREQ bit. The ABTREQ bit will then be cleared automatically. While CMDABT is set, CCIF cannot be cleared to launch a command. Aborting a program or erase operation may leave the flash or IFR space being modified in an indeterminate state.

##### NOTE

Aborting certain flash commands may take longer to abort than to execute. See the device data sheet for flash command timing specifications.

#### 6.3.1.2 Flash commands

The following table summarizes the function of all flash commands. If any column is marked with an 'X', the flash command is relevant to that particular memory resource.

| FCMD | Command                      | Program flash 0 | IFR | Function                                         |
|------|------------------------------|-----------------|-----|--------------------------------------------------|
| 00h  | Read 1s All (RD1ALL)         | x               | x   | Verify that all flash and IFR space is erased    |
| 01h  | Read 1s Block (RD1BLK)       | x               |     | Verify that a flash block is erased              |
| 02h  | Read 1s Sector (RD1SCR)      | x               |     | Verify that a flash sector is erased             |
| 03h  | Read 1s Page (RD1PG)         | x               |     | Verify that a flash page is erased               |
| 04h  | Read 1s Phrase (RD1PHR)      | x               |     | Verify that a flash phrase is erased             |
| 05h  | Read into MISR (RDMISR)      | x               |     | Generate MISR signature for range of flash pages |
| 12h  | Read 1s IFR Sector (RD1ISCR) |                 | x   | Verify that an IFR sector is erased              |
| 13h  | Read 1s IFR Page (RD1IPG)    |                 | x   | Verify that an IFR page is erased                |
| 14h  | Read 1s IFR Phrase (RD1IPH)  |                 | x   | Verify that an IFR phrase is erased              |
| 15h  | Read IFR into MISR (RDIMISR) |                 | x   | Generate MISR signature for range of IFR pages   |

*Table continues on the next page...*

| <i>Table continued from the previous page...</i> |                         |                 |     |                                          |
|--------------------------------------------------|-------------------------|-----------------|-----|------------------------------------------|
| FCMD                                             | Command                 | Program flash 0 | IFR | Function                                 |
| 23h                                              | Program Page (PGMPG)    | x               | x   | Program data to a flash or IFR page      |
| 24h                                              | Program Phrase (PGMPHR) | x               | x   | Program data to a flash or IFR phrase    |
| 40h                                              | Erase All (ERSALL)      | x               | x   | Erase all flash and IFR space if enabled |
| 42h                                              | Erase Sector (ERSSCR)   | x               | x   | Erase a flash sector                     |

### 6.3.1.3 Flash commands impacted by Block Checker and FMC access protection

The following flash commands are impacted by Block Checker and FMC access protection:

- Program Phrase (PGMPHR)
- Program Page (PGMPG)
- Erase Sector (ERSSCR)

During execution of these flash commands, a sequence of AHB writes to flash or IFR space are required with validity checked by the Block Checker or FMC. When writes are enabled by the FMU, violations detected by the FMC are reported as an access error in the FMU. The other violations are handled by the Block Checker or FMC.

Table 22. Flash Write Access Checks

| Flash Write Violation Condition                                                                                     | Block Checker | FMC | FMU |
|---------------------------------------------------------------------------------------------------------------------|---------------|-----|-----|
| Flash or IFR address out-of-range                                                                                   | x             |     |     |
| Flash or IFR write permission check fails                                                                           | x             |     |     |
| Write to IFR1 space                                                                                                 |               | x   |     |
| Write width not 32-bit                                                                                              |               | x   |     |
| Writes not enabled by FSTAT[PEWEN]                                                                                  |               | x   |     |
| First write in sequence not properly aligned per FSTAT[PEWEN]                                                       |               |     | x   |
| Non-sequential write after first aligned write in sequence                                                          |               |     | x   |
| Bus permissions for the AHB write do not match the bus permissions of the APB write that launched the flash command |               |     | x   |

### 6.3.2 Flash command descriptions

This section describes all flash commands that can be launched by a valid command write sequence. The flash module sets the FSTAT[ACCERR] bit and aborts the command execution if any of the following illegal conditions occur:

- There is an unrecognized command code in the FCCOB FCMD field.
- There is an error in an FCCOB field for the specific command. Refer to the error handling table provided for each command.

The ACCERR, PVIOL, and CMDABT flags in the FSTAT register should be cleared prior to starting a command write sequence. As described in [Launch the Command by Clearing CCIF](#), a new command cannot be launched while these flags are set.

Do not attempt to read a flash block while a flash command is running (CCIF = 0) on that same block. The flash module may return a transfer error to the FMC resulting in a bus fault. The exception to this rule is during program operations where the flash block is still readable after the command is launched up until the time the FSTAT[PERDY] flag is cleared.

---

**CAUTION**


---

Flash data must be in the erased state before being programmed. Cumulative programming of bits (adding more zeros) is not allowed.

---

### 6.3.2.1 Read 1s All Command

The Read 1s All command checks if all flash and IFR space are in the erased state.

**Table 23. Read 1s All Command FCCOB Requirements**

| FCCOB Number | FCCOB Contents |
|--------------|----------------|
| 0            | 00h (RD1ALL)   |

Upon clearing CCIF to launch the Read 1s All command, the command controller:

- verifies that all flash and IFR space are in the erased state

If all flash and IFR space are not in the erased state, the FSTAT[FAIL] flag is set. The CCIF flag sets after the Read 1s All operation completes.

**Table 24. Read 1s All Command Error Handling**

| Error Condition                                           | Error Bit     |
|-----------------------------------------------------------|---------------|
| FMU parameters not loaded from IFR1 during initialization | FSTAT[ACCERR] |
| Operation is aborted                                      | FSTAT[CMDABT] |
| FMU parameters not loaded from IFR1 during initialization | FSTAT[FAIL]   |
| Verify fails                                              | FSTAT[FAIL]   |

### 6.3.2.2 Read 1s Block Command

The Read 1s Block command checks if a flash block is in the erased state.

**Table 25. Read 1s Block Command FCCOB Requirements**

| FCCOB Number | FCCOB Contents |
|--------------|----------------|
| 0            | 01h (RD1BLK)   |
| 2            | Block address  |

Upon clearing CCIF to launch the Read 1s Block command, the command controller:

- verifies that the selected flash block is in the erased state

If the selected flash block is not in the erased state, the FSTAT[FAIL] flag is set. The CCIF flag sets after the Read 1s Block operation completes.

**Table 26. Read 1s Block Command Error Handling**

| Error Condition                                           | Error Bit     |
|-----------------------------------------------------------|---------------|
| FMU parameters not loaded from IFR1 during initialization | FSTAT[ACCERR] |

*Table continues on the next page...*

**Table 26. Read 1s Block Command Error Handling (continued)**

| Error Condition                                           | Error Bit     |
|-----------------------------------------------------------|---------------|
| Address is not valid                                      | FSTAT[ACCERR] |
| Address is not block aligned                              | FSTAT[ACCERR] |
| Operation is aborted                                      | FSTAT[CMDABT] |
| FMU parameters not loaded from IFR1 during initialization | FSTAT[FAIL]   |
| Verify fails                                              | FSTAT[FAIL]   |

### 6.3.2.3 Read 1s Sector Command

The Read 1s Sector command checks if a flash sector is in the erased state.

**Table 27. Read 1s Sector Command FCCOB Requirements**

| FCCOB Number | FCCOB Contents |
|--------------|----------------|
| 0            | 02h (RD1SCR)   |
| 2            | Sector address |

Upon clearing CCIF to launch the Read 1s Sector command, the command controller:

- verifies that the selected flash sector is in the erased state

If the selected flash sector is not in the erased state, the FSTAT[FAIL] flag is set. The CCIF flag sets after the Read 1s Sector operation completes.

**Table 28. Read 1s Sector Command Error Handling**

| Error Condition                                           | Error Bit     |
|-----------------------------------------------------------|---------------|
| FMU parameters not loaded from IFR1 during initialization | FSTAT[ACCERR] |
| Address is not valid                                      | FSTAT[ACCERR] |
| Address is not sector aligned                             | FSTAT[ACCERR] |
| Operation is aborted                                      | FSTAT[CMDABT] |
| FMU parameters not loaded from IFR1 during initialization | FSTAT[FAIL]   |
| Verify fails                                              | FSTAT[FAIL]   |

### 6.3.2.4 Read 1s Page Command

The Read 1s Page command checks if a flash page is in the erased state.

**Table 29. Read 1s Page Command FCCOB Requirements**

| FCCOB Number | FCCOB Contents |
|--------------|----------------|
| 0            | 03h (RD1PG)    |
| 2            | Page address   |

Upon clearing CCIF to launch the Read 1s Page command, the command controller:

- verifies that the selected flash page is in the erased state

If the selected flash page is not in the erased state, the FSTAT[FAIL] flag is set. The CCIF flag sets after the Read 1s Page operation completes.

**Table 30. Read 1s Page Command Error Handling**

| Error Condition                                           | Error Bit     |
|-----------------------------------------------------------|---------------|
| FMU parameters not loaded from IFR1 during initialization | FSTAT[ACCERR] |
| Address is not valid                                      | FSTAT[ACCERR] |
| Address is not page aligned                               | FSTAT[ACCERR] |
| Operation is aborted                                      | FSTAT[CMDABT] |
| FMU parameters not loaded from IFR1 during initialization | FSTAT[FAIL]   |
| Verify fails                                              | FSTAT[FAIL]   |

### 6.3.2.5 Read 1s Phrase Command

The Read 1s Phrase command checks if a flash phrase is in the erased state.

**Table 31. Read 1s Phrase Command FCCOB Requirements**

| FCCOB Number | FCCOB Contents |
|--------------|----------------|
| 0            | 04h (RD1PHR)   |
| 2            | Phrase address |

Upon clearing CCIF to launch the Read 1s Phrase command, the command controller:

- verifies that the selected flash phrase is in the erased state

If the selected flash phrase is not in the erased state, the FSTAT[FAIL] flag is set. The CCIF flag sets after the Read 1s Phrase operation completes.

**Table 32. Read 1s Phrase Command Error Handling**

| Error Condition                                           | Error Bit     |
|-----------------------------------------------------------|---------------|
| FMU parameters not loaded from IFR1 during initialization | FSTAT[ACCERR] |
| Address is not valid                                      | FSTAT[ACCERR] |
| Address is not phrase aligned                             | FSTAT[ACCERR] |
| Operation is aborted                                      | FSTAT[CMDABT] |
| FMU parameters not loaded from IFR1 during initialization | FSTAT[FAIL]   |
| Verify fails                                              | FSTAT[FAIL]   |

### 6.3.2.6 Read into MISR command

The Read into MISR operation generates a signature based on the contents of the selected flash memory using an embedded MISR.

**Table 33. Read into MISR Command FCCOB Requirements**

| FCCOB Number    | FCCOB Contents              |
|-----------------|-----------------------------|
| 0               | 05h (RDMISR) [7:0]          |
| 2               | Starting flash page address |
| 3               | Ending flash phrase address |
| 4               | Word 0 of MISR seed         |
| 5               | Word 1 of MISR seed         |
| 6               | Word 2 of MISR seed         |
| 7               | Word 3 of MISR seed         |
| Returned values |                             |
| 4               | Word 0 of MISR signature    |
| 5               | Word 1 of MISR signature    |
| 6               | Word 2 of MISR signature    |
| 7               | Word 3 of MISR signature    |

Upon clearing CCIF to launch the Read into MISR command, the command controller:

1. initializes the MISR with the seed provided
2. processes flash data starting with the starting flash page address provided
3. continues until the ending flash phrase address has been processed (must be the last phrase in a page)
4. returns the resulting signature into the FCCOB register bank unless an uncorrectable ECC fault is detected

The CCIF flag sets after the Read into MISR operation completes. If the operation is aborted by setting FCTRL[ABTREQ], a signature will not be returned if the abort occurs prior to the operation writing the signature.

MISR polynomial is  $X^{128} + X^{126} + X^{101} + X^{99} + 1$ .

**Table 34. Read into MISR Command Error Handling**

| Error Condition                                           | Error Bit     |
|-----------------------------------------------------------|---------------|
| FMU parameters not loaded from IFR1 during initialization | FSTAT[ACCERR] |
| Address is not valid                                      | FSTAT[ACCERR] |
| Starting address is not flash page aligned                | FSTAT[ACCERR] |
| Ending address is not flash phrase aligned                | FSTAT[ACCERR] |
| Ending address is not the last phrase in a page           | FSTAT[ACCERR] |
| Starting address is larger than the ending address        | FSTAT[ACCERR] |
| Requested range crosses a flash block boundary            | FSTAT[ACCERR] |
| Operation is aborted                                      | FSTAT[CMDABT] |
| FMU parameters not loaded from IFR1 during initialization | FSTAT[FAIL]   |
| Uncorrectable ECC error is detected                       | FSTAT[FAIL]   |

### 6.3.2.7 Read 1s IFR Sector Command

The Read 1s IFR Sector command checks if an IFR sector is in the erased state.

**Table 35. Read 1s IFR Sector Command FCCOB Requirements**

| FCCOB Number | FCCOB Contents     |
|--------------|--------------------|
| 0            | 12h (RD1ISCR)      |
| 2            | IFR sector address |

Upon clearing CCIF to launch the Read 1s IFR Sector command, the command controller:

- verifies that the selected IFR sector is in the erased state

If the selected IFR sector is not in the erased state, the FSTAT[FAIL] flag is set. The CCIF flag sets after the Read 1s IFR Sector operation completes.

**Table 36. Read 1s IFR Sector Command Error Handling**

| Error Condition                                           | Error Bit     |
|-----------------------------------------------------------|---------------|
| FMU parameters not loaded from IFR1 during initialization | FSTAT[ACCERR] |
| Address is not valid                                      | FSTAT[ACCERR] |
| Address is not IFR sector aligned                         | FSTAT[ACCERR] |
| Operation is aborted                                      | FSTAT[CMDABT] |
| FMU parameters not loaded from IFR1 during initialization | FSTAT[FAIL]   |
| Verify fails                                              | FSTAT[FAIL]   |

### 6.3.2.8 Read 1s IFR Page Command

The Read 1s IFR Page command checks if an IFR page is in the erased state.

**Table 37. Read 1s IFR Page Command FCCOB Requirements**

| FCCOB Number | FCCOB Contents   |
|--------------|------------------|
| 0            | 13h (RD1IPG)     |
| 2            | IFR page address |

Upon clearing CCIF to launch the Read 1s IFR Page command, the command controller:

- verifies that the selected IFR page is in the erased state

If the selected IFR page is not in the erased state, the FSTAT[FAIL] flag is set. The CCIF flag sets after the Read 1s IFR Page operation completes.

**Table 38. Read 1s IFR Page Command Error Handling**

| Error Condition                                           | Error Bit     |
|-----------------------------------------------------------|---------------|
| FMU parameters not loaded from IFR1 during initialization | FSTAT[ACCERR] |
| Address is not valid                                      | FSTAT[ACCERR] |
| Address is not IFR page aligned                           | FSTAT[ACCERR] |
| Operation is aborted                                      | FSTAT[CMDABT] |

*Table continues on the next page...*

**Table 38. Read 1s IFR Page Command Error Handling (continued)**

| Error Condition                                           | Error Bit   |
|-----------------------------------------------------------|-------------|
| FMU parameters not loaded from IFR1 during initialization | FSTAT[FAIL] |
| Verify fails                                              | FSTAT[FAIL] |

### 6.3.2.9 Read 1s IFR Phrase Command

The Read 1s IFR Phrase command checks if an IFR phrase is in the erased state.

**Table 39. Read 1s IFR Phrase Command FCCOB Requirements**

| FCCOB Number | FCCOB Contents     |
|--------------|--------------------|
| 0            | 14h (RD1IPHR)      |
| 2            | IFR phrase address |

Upon clearing CCIF to launch the Read 1s IFR Phrase command, the command controller:

- verifies that the selected IFR phrase is in the erased state

If the selected IFR phrase is not in the erased state, the FSTAT[FAIL] flag is set. The CCIF flag sets after the Read 1s IFR Phrase operation completes.

**Table 40. Read 1s IFR Phrase Command Error Handling**

| Error Condition                                           | Error Bit     |
|-----------------------------------------------------------|---------------|
| FMU parameters not loaded from IFR1 during initialization | FSTAT[ACCERR] |
| Address is not valid                                      | FSTAT[ACCERR] |
| Address is not IFR phrase aligned                         | FSTAT[ACCERR] |
| Operation is aborted                                      | FSTAT[CMDABT] |
| FMU parameters not loaded from IFR1 during initialization | FSTAT[FAIL]   |
| Verify fails                                              | FSTAT[FAIL]   |

### 6.3.2.10 Read IFR into MISR command

The Read IFR into MISR operation generates a signature based on the contents of the selected IFR space using an embedded MISR.

**Table 41. Read IFR into MISR Command FCCOB Requirements**

| FCCOB Number | FCCOB Contents            |
|--------------|---------------------------|
| 0            | 15h (RDIMISR) [7:0]       |
| 2            | Starting IFR page address |
| 3            | Ending IFR phrase address |
| 4            | Word 0 of MISR seed       |
| 5            | Word 1 of MISR seed       |
| 6            | Word 2 of MISR seed       |

*Table continues on the next page...*

**Table 41.** Read IFR into MISR Command FCCOB Requirements (continued)

| FCCOB Number    | FCCOB Contents           |
|-----------------|--------------------------|
| 7               | Word 3 of MISR seed      |
| Returned values |                          |
| 4               | Word 0 of MISR signature |
| 5               | Word 1 of MISR signature |
| 6               | Word 2 of MISR signature |
| 7               | Word 3 of MISR signature |

Upon clearing CCIF to launch the Read IFR into MISR command, the command controller:

1. initializes the MISR with the seed provided
2. processes IFR data starting with the starting IFR page address provided
3. continues until the ending IFR phrase has been processed (must be the last phrase in a page)
4. returns the resulting signature into the FCCOB register bank unless an uncorrectable ECC fault is detected

The CCIF flag sets after the Read IFR into MISR operation completes. If the operation is aborted by setting FCTRL[ABTREQ], a signature will not be returned if the abort occurs prior to the operation writing the signature.

MISR polynomial is  $X^{128} + X^{126} + X^{101} + X^{99} + 1$ .

**Table 42.** Read IFR into MISR Command Error Handling

| Error Condition                                           | Error Bit     |
|-----------------------------------------------------------|---------------|
| FMU parameters not loaded from IFR1 during initialization | FSTAT[ACCERR] |
| Address is not valid                                      | FSTAT[ACCERR] |
| Starting address is not IFR page aligned                  | FSTAT[ACCERR] |
| Ending address is not IFR phrase aligned                  | FSTAT[ACCERR] |
| Ending address is not the last phrase in a page           | FSTAT[ACCERR] |
| Starting address is larger than the ending address        | FSTAT[ACCERR] |
| Operation is aborted                                      | FSTAT[CMDABT] |
| FMU parameters not loaded from IFR1 during initialization | FSTAT[FAIL]   |
| Uncorrectable ECC error is detected                       | FSTAT[FAIL]   |

### 6.3.2.11 Program Page command

The Program Page operation programs 32 words of data to a previously erased flash or IFR page.

#### CAUTION

The page must be in the erased state before being programmed. Cumulative programming of bits (back-to-back program operations without an intervening erase) within a page is not allowed.

**Table 43.** Program Page Command FCCOB Requirements

| FCCOB Number | FCCOB Contents    |
|--------------|-------------------|
| 0            | 23h (PGMPG) [7:0] |

Upon clearing CCIF to launch the Program Page command, the command controller:

1. sets FSTAT[PEWEN] to enable writes to the flash and IFR space in the system memory map
2. waits for the user to write 32 consecutive words to the flash or IFR space with the first write being page aligned
3. clears FSTAT[PEWEN] field
4. sets FSTAT[PERDY]
5. waits for the user to clear FSTAT[PERDY]
6. programs the data into the targeted page written to in step 2
7. verifies bits to be programmed are programmed to the program verify level

The CCIF flag sets after the Program Page operation completes. The Program Page operation can be aborted by setting FCTRL[ABTREQ]. If the operation is aborted, the operation terminates with the FSTAT[CMDABT] flag set. Once CCIF is set, the Program Page command may be repeated (same addresses, same data) to complete the program operation without erasing the sector containing the targeted page. Invalid writes to flash or IFR space based on Block Checker or FMC access protection are trapped outside of the flash module.

**Table 44. Program Page Command Error Handling**

| Error Condition                                                                                                      | Error Bit     |
|----------------------------------------------------------------------------------------------------------------------|---------------|
| FMU parameters not loaded from IFR1 during initialization                                                            | FSTAT[ACCERR] |
| Protection level of the writes to flash or IFR space do not match the protection level of the command write sequence | FSTAT[ACCERR] |
| Initial address is not page aligned and subsequent addresses phrase aligned                                          | FSTAT[ACCERR] |
| Number of writes to flash or IFR space is more than expected                                                         | FSTAT[ACCERR] |
| Operation is aborted                                                                                                 | FSTAT[CMDABT] |
| FMU parameters not loaded from IFR1 during initialization                                                            | FSTAT[FAIL]   |
| Verify fails                                                                                                         | FSTAT[FAIL]   |

### 6.3.2.11.1 Page programming

The standard process of programming one or more flash or IFR pages is as follows:

1. If required, launch the Erase Sector command to erase the flash or IFR sector to be programmed (repeat for additional sectors).
2. Launch the Program Page command to enable writes to the flash space.
3. After the command controller sets FSTAT[PEWEN], write 32 consecutive words to the flash space with the first word page aligned. The data written to the flash space is not readable until the program operation has successfully completed.
4. After the flash page has been written, the command controller will stall and set FSTAT[PERDY].
5. Clear PERDY allowing the command controller to resume and program the 32 words into the flash or IFR space written to in step 3.
6. Wait for CCIF to set indicating the program operation has completed.
7. To program additional flash or IFR pages in previously erased flash memory, repeat steps 2 through 6.

### 6.3.2.12 Program Phrase command

The Program Phrase operation programs 4 words of data to a previously erased flash or IFR phrase.

**CAUTION**

The phrase must be in the erased state before being programmed. Cumulative programming of bits (back-to-back program operations without an intervening erase) within a phrase is not allowed.

**Table 45. Program Phrase Command FCCOB Requirements**

| FCCOB Number | FCCOB Contents     |
|--------------|--------------------|
| 0            | 24h (PGMPHR) [7:0] |

Upon clearing CCIF to launch the Program Phrase command, the command controller:

1. sets FSTAT[PEWEN] to enable writes to the flash and IFR space in the system memory map
2. waits for the user to write 4 consecutive words to the flash or IFR space with the first write being phrase aligned
3. clears FSTAT[PEWEN] field
4. sets FSTAT[PERDY]
5. waits for the user to clear FSTAT[PERDY]
6. programs the data into the targeted phrase written to in step 2.
7. verifies bits to be programmed are programmed to the program verify level

The CCIF flag sets after the Program Phrase operation completes. The Program Phrase operation can be aborted by setting FCTRL[ABTREQ]. If the operation is aborted, the operation terminates with the FSTAT[CMDABT] flag set. Once CCIF is set and the CMDABT flag is cleared, the Program Phrase command may be repeated (same addresses, same data) to complete the program operation without erasing the sector containing the targeted phrase. Invalid writes to flash or IFR space based on Block Checker or FMC access protection are trapped outside of the flash module.

**Table 46. Program Phrase Command Error Handling**

| Error Condition                                                                                                      | Error Bit     |
|----------------------------------------------------------------------------------------------------------------------|---------------|
| FMU parameters not loaded from IFR1 during initialization                                                            | FSTAT[ACCERR] |
| Protection level of the writes to flash or IFR space do not match the protection level of the command write sequence | FSTAT[ACCERR] |
| Address is not phrase aligned                                                                                        | FSTAT[ACCERR] |
| Number of writes to flash or IFR space is more than expected                                                         | FSTAT[ACCERR] |
| Operation is aborted                                                                                                 | FSTAT[CMDABT] |
| FMU parameters not loaded from IFR1 during initialization                                                            | FSTAT[FAIL]   |
| Verify fails                                                                                                         | FSTAT[FAIL]   |

### 6.3.2.12.1 Phrase programming

The standard process of programming one or more flash or IFR phrases is as follows:

1. If required, launch the Erase Sector command to erase the flash or IFR sector to be programmed (repeat for additional sectors).
2. Launch the Program Phrase command to enable writes to the flash and IFR space.
3. After the command controller sets FSTAT[PEWEN], write 4 consecutive words to the flash or IFR space with the first word phrase aligned. The data written to the flash or IFR space is not readable until the program operation has successfully completed.
4. After the flash or IFR phrase has been written, the command controller will stall the operation and set FSTAT[PERDY].

5. Clear PERDY allowing the command controller to resume and program the 4 words into the flash or IFR space written to in step 3.
6. Wait for CCIF to set indicating the program operation has completed.
7. To program additional flash or IFR phrases in previously erased flash memory, repeat steps 2 through 6.

### 6.3.2.13 Erase All command

The Erase All operation erases all flash and IFR space if enabled by the MCU.

**Table 47. Erase All Command FCCOB Requirements**

| FCCOB Number | FCCOB Contents     |
|--------------|--------------------|
| 0            | 40h (ERSALL) [7:0] |

Upon clearing CCIF to launch the Erase All command, the command controller:

1. erases flash block 0 sector-by-sector
2. verifies flash block 0 is erased; if not, skips IFR space in block 0
3. erases IFR space in block 0 sector-by-sector
4. verifies IFR space in block 0 is erased
5. clears FSTAT[CMDP] flag

The CCIF flag sets after the Erase All operation completes. If either the flash or IFR space is not in the erased state, FSTAT[FAIL] sets.

**Table 48. Erase All Command Error Handling**

| Error Condition                                           | Error Bit     |
|-----------------------------------------------------------|---------------|
| FMU parameters not loaded from IFR1 during initialization | FSTAT[ACCERR] |
| Command is disabled by the MCU                            | FSTAT[PVIOL]  |
| Operation is aborted                                      | FSTAT[CMDBT]  |
| FMU parameters not loaded from IFR1 during initialization | FSTAT[FAIL]   |
| Verify fails                                              | FSTAT[FAIL]   |

### 6.3.2.14 Erase Sector command

The Erase Sector operation erases the IFR sector to prepare the sector for programming.

**Table 49. Erase Sector Command FCCOB Requirements**

| FCCOB Number | FCCOB Contents     |
|--------------|--------------------|
| 0            | 42h (ERSSCR) [7:0] |

Upon clearing CCIF to launch the Erase Sector command, the command controller:

1. sets FSTAT[PEWEN] to enable writes to the flash and IFR space in the system memory map
2. waits for the user to write 4 consecutive words to the flash or IFR space with the first write being phrase (or sector) aligned
3. clears FSTAT[PEWEN] field
4. sets FSTAT[PERDY]

5. waits for the user to clear FSTAT[PERDY]
6. erases the selected flash or IFR sector
7. verifies the selected flash or IFR sector is erased

If the selected flash or IFR sector is not in the erased state, FSTAT[FAIL] is set. The CCIF flag sets after the Erase Sector operation completes. The Erase Sector operation can be aborted by setting FCTRL[ABTREQ]. If the operation is aborted, the operation terminates with the FSTAT[CMDABT] flag set. Once CCIF is set, the Erase Sector command may be repeated to complete the erase operation. Invalid writes to flash or IFR space based on Block Checker or FMC access protection are trapped outside of the flash module.

**Table 50. Erase Sector Command Error Handling**

| Error Condition                                                                                                      | Error Bit     |
|----------------------------------------------------------------------------------------------------------------------|---------------|
| FMU parameters not loaded from IFR1 during initialization                                                            | FSTAT[ACCERR] |
| Protection level of the writes to flash or IFR space do not match the protection level of the command write sequence | FSTAT[ACCERR] |
| Address is not flash or IFR phrase aligned                                                                           | FSTAT[ACCERR] |
| Operation is aborted                                                                                                 | FSTAT[CMDABT] |
| IFR Sector is protected (see FCNFG register)                                                                         | FSTAT[PVIOL]  |
| FMU parameters not loaded from IFR1 during initialization                                                            | FSTAT[FAIL]   |
| Verify fails                                                                                                         | FSTAT[FAIL]   |

### 6.3.3 Mass Erase

If enabled by the MCU, MCU resources can be used to launch a mass erase operation without accessing the flash registers.

To know how to enable/disable mass erase for your device, refer the chip-specific section.

The status of the mass erase request is reflected in the FCNFG[ERSREQ] bit. When launched, the mass erase operation occurs regardless of the state of the CMDP, ACCERR, PVIOL, or CMDABT flags in the FSTAT register but requires FSTAT[CCIF] to be set and the MCU to enable mass erase. When mass erase is launched with CCIF set, the CMDP, CCIF, CWSABT, PVIOL, and CMDABT flags in the FSTAT register clear. The ACCERR and FAIL flags also clear unless the FMU parameters were not loaded from IFR1 during initialization in which case the mass erase operation terminates without performing any erase of flash memory.

Upon successful launch of the mass erase operation, the command controller (same steps as the Erase All command):

1. erases flash block 0 sector-by-sector
2. verifies flash block 0 is erased; if not, skips IFR space in block 0
3. erases IFR space in block 0 sector-by-sector
4. verifies IFR space in block 0 is erased

The CCIF flag sets and the ERSREQ bit clears once the operation completes and the FSTAT[FAIL] flag sets if any verify step fails during the mass erase operation. This method of erasing the flash memory cannot be aborted by setting FCTRL[ABTREQ].

### 6.3.4 Modes

#### 6.3.4.1 Sleep mode

If the CPU enters sleep mode while a flash command is executing, the flash module can wake the CPU via the command complete interrupt (see [Interrupts](#)).

### 6.3.4.2 Non-Active Power mode

If a flash command is active ( $CCIF = 0$ ) when the MCU requests a non-active power mode, the command execution completes before the MCU is allowed to enter the non-active power mode.

### 6.3.4.3 Low Speed Active Power mode

While the MCU is in low speed active power mode ( $FCTRL[LSACTIVE]=1$ ), the flash module will accept flash commands. While a flash command is in progress ( $FSTAT[CCIF]=0$ ), the LSACTIVE bit is not writable.

### 6.3.5 Clocking

This module has no clocking considerations.

### 6.3.6 Interrupts

The flash module can generate interrupt requests to the MCU upon the occurrence of various flash module events. These interrupt events and their associated status and control bits are shown in the following table.

**Table 51. Flash Module Interrupt Sources**

| Flash Event              | Readable Status Bit | Interrupt Enable Bit |
|--------------------------|---------------------|----------------------|
| Flash Command Complete   | $FSTAT[CCIF]$       | $FCNFG[CCIE]$        |
| Flash ECC Fault Detected | $FSTAT[DFDIF]$      | $FCNFG[DFDIE]$       |

**NOTE**

Vector addresses and their relative interrupt priority are determined at the MCU level.

## 6.4 External signals

The flash module contains no signals that connect off-chip.

## 6.5 Initialization

On each reset, the command controller initializes the following based on IFR1 content:

1.  $FCTRL[RWSC]$
2. FMU Parameters ( $FMUPARM$ )

The  $FSTAT[CCIF]$  flag is cleared throughout the initialization flow. The flash module also holds off all access to flash registers and flash memory during initialization. Completion of the initialization flow is marked by setting  $FSTAT[CCIF]$ . If an uncorrectable ECC error is detected during initialization, the  $FSTAT[FAIL]$  flag sets. The FAIL flag also sets if FMU parameters are not loaded from IFR1 during initialization. In this case, attempts to launch a flash command terminate with the ACCERR and FAIL flags set. The recommendation is to refrain from launching flash commands if the FAIL flag sets after initialization.

If a reset occurs while any flash command is in progress, that command is immediately aborted. The state of the flash memory or IFR space being programmed or erased is not guaranteed. Command operations do not automatically resume after exiting reset.

## 6.6 Memory map and registers

This section describes the flash memory map for IFR/IFR1 space and registers. See the MCU system memory map for the location of all flash memory space and registers. Data read from unimplemented memory space in the flash module is undefined.

### 6.6.1 IFR description

Each flash block contains IFR space separate from the main flash memory. IFR space is memory mapped (see the MCU system memory map). IFR space is divided into IFR pages programmable using the Program Page command. IFR pages are further divided into IFR phrases programmable using the Program Phrase command. Once programmed, IFR phrases can be reprogrammed after a successful erase using the Erase Sector command operation unless the IFR sector is protected by the FCNFG register.

**Table 52. IFR map**

| Offset Byte Address  | IFR Field Size (Bytes) |
|----------------------|------------------------|
| Block 0 IFR Sector 0 |                        |
| 0000h-1FFFh          | 8,192                  |
| Block 0 IFR Sector 1 |                        |
| 2000h-3FFFh          | 8,192                  |
| Block 0 IFR Sector 2 |                        |
| 4000h-5FFFh          | 8,192                  |
| Block 0 IFR Sector 3 |                        |
| 6000h-7FFFh          | 8,192                  |

Each flash block also contains IFR1 space separate from the main flash memory. IFR1 space in program flash block 0 is memory mapped for read-only access (see the MCU system memory map). IFR1 space cannot be erased or programmed by the user.

**Table 53. IFR1 map**

| Offset Byte Address | IFR1 Field Size (Bytes) |
|---------------------|-------------------------|
| Block 0 IFR1 Sector |                         |
| 0000h-15FFh         | 5,632                   |
| 1600h-16FFh         | 256                     |
| 1700h-1FFFh         | 2,304                   |

### 6.6.2 Register descriptions

The flash module contains a set of memory-mapped control and status registers.

**NOTE**

While a command is running (FSTAT[CCIF]=0), register writes are allowed to FSTAT[PERDY,DFDIF,CWSABT], FCNFG, and FCTRL[ABTREQ,FDFD,RWSC].

#### 6.6.2.1 Flash register descriptions

##### 6.6.2.1.1 Flash memory map

FMU0.MSF1 base address: 4009\_5000h

| Offset | Register                                       | Width<br>(In bits) | Access | Reset value                 |
|--------|------------------------------------------------|--------------------|--------|-----------------------------|
| 0h     | Flash Status Register (FSTAT)                  | 32                 | RW     | <a href="#">See section</a> |
| 4h     | Flash Configuration Register (FCNFG)           | 32                 | RW     | <a href="#">See section</a> |
| 8h     | Flash Control Register (FCTRL)                 | 32                 | RW     | <a href="#">See section</a> |
| 10h    | Flash Common Command Object Registers (FCCOB0) | 32                 | RW     | 0000_0000h                  |
| 14h    | Flash Common Command Object Registers (FCCOB1) | 32                 | RW     | 0000_0000h                  |
| 18h    | Flash Common Command Object Registers (FCCOB2) | 32                 | RW     | 0000_0000h                  |
| 1Ch    | Flash Common Command Object Registers (FCCOB3) | 32                 | RW     | 0000_0000h                  |
| 20h    | Flash Common Command Object Registers (FCCOB4) | 32                 | RW     | 0000_0000h                  |
| 24h    | Flash Common Command Object Registers (FCCOB5) | 32                 | RW     | 0000_0000h                  |
| 28h    | Flash Common Command Object Registers (FCCOB6) | 32                 | RW     | 0000_0000h                  |
| 2Ch    | Flash Common Command Object Registers (FCCOB7) | 32                 | RW     | 0000_0000h                  |

### 6.6.2.1.2 Flash Status Register (FSTAT)

#### Offset

| Register | Offset |
|----------|--------|
| FSTAT    | 0h     |

#### Function

The FSTAT register reports the operational status of the flash module.

##### NOTE

When set, ACCERR, PVIOL, and CMDABT flags prevent the launch of any more commands until the flag is cleared (by writing a one to it).

##### CAUTION

When clearing the DFDIF flag, be careful not to use read-modify-write on the entire FSTAT register and inadvertently clear CCIF to launch a command.

**Diagram**

| Bits  | 31     | 30  | 29 | 28   | 27    | 26     | 25 | 24   | 23      | 22      | 21    | 20 | 19         | 18    | 17   | 16 |
|-------|--------|-----|----|------|-------|--------|----|------|---------|---------|-------|----|------------|-------|------|----|
| R     | PERDY  | 0   |    |      | PEWEN |        |    | 0    |         |         |       |    | SALV_US... | DFDIF |      |    |
|       | W      | W1C |    |      |       |        |    |      |         |         |       |    | W1C        |       |      |    |
| Reset | 0      | 0   | 0  | 0    | 0     | 0      | 0  | 0    | 0       | 0       | 0     | 0  | 0          | 0     | 0    | 0  |
| Bits  | 15     | 14  | 13 | 12   | 11    | 10     | 9  | 8    | 7       | 6       | 5     | 4  | 3          | 2     | 1    | 0  |
| R     | CMDDID |     |    | CMDP | 0     | CMDPRT |    | CCIF | CWSA_BT | ACCE_RR | PVIOL | 0  | CMDABT     | 0     | FAIL |    |
|       |        |     |    |      |       | W1C    |    | W1C  | W1C     | W1C     | W1C   |    | W1C        |       |      |    |
| Reset | 0      | 0   | 0  | 0    | 0     | 0      | 0  | 0    | 1       | 0       | 0     | 0  | 0          | 0     | 0    | u  |

**Fields**

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>PERDY    | Program-Erase Ready Control/Status Flag<br><br>The PERDY flag is set by the command controller when a program or sector erase command operation has successfully completed the write phase. The command controller will stall the command operation until the user clears the PERDY flag by writing a 1 to PERDY. Failure to clear PERDY will leave the command controller stalled but the flash or IFR space targeted by the command operation will remain readable by the FMC. If FCTRL[ABTREQ] is set while the PERDY flag is set, the command controller will clear PERDY, abort the command operation, and set both CCIF and CMDABT.<br><br>0b - Program or sector erase command operation not stalled<br>1b - Program or sector erase command operation ready to execute                                                                                                   |
| 30-26<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 25-24<br>PEWEN | Program-Erase Write Enable Control<br><br>During program or sector erase command operations, writes are enabled to flash or IFR space in the system memory map. For phrase programming or sector erase, writes are enabled for 4 consecutive words (16 bytes) with address phrase aligned. For page programming, writes are enabled for 8 consecutive phrases (128 bytes) with address page aligned. For programming, data written to erased flash or IFR space for program commands is not available until the program operation has successfully completed. PEWEN will not assert if FMU parameters were not loaded from IFR1 during initialization.<br><br>00b - Writes are not enabled<br>01b - Writes are enabled for one flash or IFR phrase (phrase programming, sector erase)<br>10b - Writes are enabled for one flash or IFR page (page programming)<br>11b - Reserved |
| 23-18<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17<br>SALV_USED | <p>Salvage Used for Erase operation</p> <p>This flag indicates salvage was used during the last Erase Sector, Erase All, or Mass Erase operation and is valid at the end of the operation. Salvage involves using ECC to pass erase verify allowing single-bit faults per phrase verified. This flag remains valid until any flash command or Mass Erase operation launches at which time the flag clears. Use of salvage does not guarantee that the erase operation succeeds but only that salvage was used on at least one phrase.</p> <p>0b - Salvage not used during last operation</p> <p>1b - Salvage used during the last erase operation</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 16<br>DFDIF     | <p>Double Bit Fault Detect Interrupt Flag</p> <p>The DFDIF flag indicates an uncorrectable ECC fault was detected during a valid flash read access from the FMC. The DFDIF flag is cleared by writing a 1 to DFDIF. Writing a 0 to DFDIF has no effect.</p> <p>0b - Double bit fault not detected during a valid flash read access</p> <p>1b - Double bit fault detected (or FCTRL[FDFD] is set) during a valid flash read access</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 15-12<br>CMDDID | <p>Command domain ID</p> <p>While the CMDP flag is set, the CMDDID bits reflect the domain ID of the write transaction controlling a command write sequence or aborting a command operation. Writes to load an FCCOB register, clear CCIF, clear PERDY, or write FCTRL[LSACTIVE] must have the same domain ID as the write transaction that started the command write sequence. The CMDDID bits persist after the CMDP flag clears until the CMDP flag sets again at the start of a new command write sequence. Writes to clear the CWSABT, ACCERR, PVIOL, or CMDABT flags are not influenced by the state of the CMDDID bits.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 11<br>CMDP      | <p>Command protection status flag</p> <p>The CMDP flag sets when a command write sequence starts with a write to load an existing FCCOB register or clear CCIF while ACCERR, PVIOL, and CMDABT are clear. Clearing the CWSABT, ACCERR, PVIOL, or CMDABT flags as part of a command write sequence will not set the CMDP flag. While the CMDP flag is set, the protection level of any subsequent write transaction to load an FCCOB register, clear CCIF, clear PERDY, or write FCTRL[LSACTIVE] must match the CMDPRT bits and the domain ID must match the CMDDID bits.</p> <p>The CMDP flag remains set until cleared when CCIF is set after a command operation or Power Down recovery completes unless the CMDABT flag is set. The CMDP flag is cleared even if the operation ends with ACCERR or PVIOL set. When the CMDP flag is cleared, the CMDPRT and CMDDID bits remain unchanged.</p> <p>The CMDP flag is also cleared by a mass erase request with CCIF set.</p> <p>0b - Command protection level and domain ID are stale</p> <p>1b - Command protection level (CMDPRT) and domain ID (CMDDID) are set</p> |
| 10<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 9-8<br>CMDPRT   | Command protection level                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | <p>While the CMDP flag is set, the CMDPRT bits reflect the secure/privilege protection level of the write transaction controlling a command write sequence or aborting a command operation. Writes to load an existing FCCOB register, clear CCIF, clear PERDY, or write FCTRL[LSACTIVE] must occur with the same protection level as indicated by the CMDPRT bits. Writes to clear the CWSABT, ACCERR, PVIOL, or CMDABT flags are not influenced by the state of the CMDPRT bits.</p> <p>If FCTRL[ABTREQ] is set while CCIF is high or low, the CMDPRT bits will change to reflect the security/privilege protection level of the write transaction that set the ABTREQ bit.</p> <ul style="list-style-type: none"> <li>00b - Secure, normal access</li> <li>01b - Secure, privileged access</li> <li>10b - Nonsecure, normal access</li> <li>11b - Nonsecure, privileged access</li> </ul> |
| 7<br>CCIF   | <p>Command Complete Interrupt Flag</p> <p>The CCIF flag indicates that a flash command has completed. The CCIF flag is cleared by writing a 1 to CCIF to launch a flash command. The CCIF flag stays low until the command completes.</p> <p>The CCIF flag is cleared by a mass erase request with CCIF set. The CCIF flag is also cleared upon entry into Deep Sleep, Power Down, and Deep Power Down modes and stays low until the end of recovery from these non-active power modes.</p> <p>The CCIF flag is reset to 0 but is set to 1 at the end of flash initialization.</p> <ul style="list-style-type: none"> <li>0b - Flash command, initialization, or power mode recovery in progress</li> <li>1b - Flash command, initialization, or power mode recovery has completed</li> </ul>                                                                                                |
| 6<br>CWSABT | <p>Command Write Sequence Abort Flag</p> <p>The CWSABT flag indicates whether a request to abort a command write sequence prior to command launch has been granted. If FCTRL[ABTREQ] is set while CCIF is high, the CWSABT flag will get set. Once CWSABT is set, ABTREQ will get cleared. While the CWSABT flag is set, ABTREQ cannot be set. The CWSABT flag is cleared by writing a 1 to CWSABT while CCIF is set or clear and ABTREQ is clear. Writing a 0 to the CWSABT flag has no effect.</p> <p>The CWSABT flag is cleared by a mass erase request with CCIF set.</p> <ul style="list-style-type: none"> <li>0b - Command write sequence not aborted</li> <li>1b - Command write sequence aborted</li> </ul>                                                                                                                                                                         |
| 5<br>ACCERR | <p>Command Access Error Flag</p> <p>The ACCERR flag indicates an illegal attempt was made to launch a flash command due to a violation of the command write sequence or by providing invalid command parameters. The ACCERR flag also sets during command execution if FMU parameters were not loaded from IFR1 during initialization. While the ACCERR flag is set, the CCIF flag cannot be cleared to launch a command. The ACCERR flag is cleared by writing a 1 to ACCERR while CCIF is set. Writing a 0 to the ACCERR flag has no effect.</p> <p>The ACCERR flag is cleared by a mass erase request with CCIF set but is not cleared during Power Down recovery.</p>                                                                                                                                                                                                                    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 0b - No access error detected<br>1b - Access error detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4<br>PVIOL  | Command Protection Violation Flag<br>The PVIOL flag indicates an attempt was made to modify a protected area of flash memory during a command operation. While the PVIOL flag is set, the CCIF flag cannot be cleared to launch a command. The PVIOL flag is cleared by writing a 1 to PVIOL while CCIF is set. Writing a 0 to the PVIOL flag has no effect.<br>The PVIOL flag is cleared by a mass erase request with CCIF set but is not cleared during Power Down recovery.<br>0b - No protection violation detected<br>1b - Protection violation detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2<br>CMDABT | Command Abort Flag<br>The CMDABT flag indicates FCTRL[ABTREQ] was set during a command operation while CCIF was clear. This event will result in the termination of the operation unless it occurs during the exit routine of the operation. Once CMDABT is set, ABTREQ will get cleared. While the CMDABT flag is set, ABTREQ cannot be set and the CCIF flag cannot be cleared to launch a command. The CMDABT flag is cleared by writing a 1 to CMDABT while CCIF is set and ABTREQ is clear. Writing a 0 to the CMDABT flag has no effect.<br>The CMDABT flag is cleared by a mass erase request with CCIF set.<br>0b - No command abort detected<br>1b - Command abort detected                                                                                                                                                                                                                                                                                                                                                                                |
| 1<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0<br>FAIL   | Command Fail Flag<br>The FAIL flag is set if an error is detected during execution of a flash command, mass erase operation, or flash initialization. If the FAIL flag sets along with ACCERR after launching a flash command or mass erase operation, FMU parameters were not loaded from IFR1 during initialization and a clean POR where FMU parameters are successfully loaded is required to clear the FAIL flag. As a status flag, this bit cannot (and need not) be cleared by the user like some of the other flags in this register.<br>The value of the FAIL flag for "command-N" is valid only at the end of the "command-N" execution when CCIF=1 and before the next command has been launched. At some point during the execution of "command-N+1," the FAIL flag is cleared unless FMU parameters were not loaded from IFR1 during initialization.<br>The FAIL flag is cleared by a mass erase request with CCIF set unless FMU parameters were not loaded from IFR1 during initialization. The FAIL flag is not cleared during Power Down recovery. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                |
|-------|-------------------------|
|       | 0b - Error not detected |
|       | 1b - Error detected     |

### 6.6.2.1.3 Flash Configuration Register (FCNFG)

#### Offset

| Register | Offset |
|----------|--------|
| FCNFG    | 4h     |

#### Function

This register provides information on the current functional state of the flash module.

#### Diagram

| Bits  | 31      | 30 | 29 | 28 | 27         | 26 | 25   | 24 | 23 | 22 | 21 | 20 | 19    | 18 | 17 | 16 |  |
|-------|---------|----|----|----|------------|----|------|----|----|----|----|----|-------|----|----|----|--|
| R     | ERSIEN1 |    |    |    | ERSIENO    |    |      |    | 0  |    |    |    | DFDIE |    |    |    |  |
| W     |         |    |    |    |            |    |      |    |    |    |    |    |       |    |    |    |  |
| Reset | u       | u  | u  | u  | u          | u  | u    | u  | 0  | 0  | 0  | 0  | 0     | 0  | 0  | 0  |  |
| Bits  | 15      | 14 | 13 | 12 | 11         | 10 | 9    | 8  | 7  | 6  | 5  | 4  | 3     | 2  | 1  | 0  |  |
| R     | 0       |    |    |    | ERSR<br>EQ |    | CCIE | 0  |    |    |    | 0  |       |    |    |    |  |
| W     |         |    |    |    |            |    |      |    |    |    |    |    |       |    |    |    |  |
| Reset | 0       | 0  | 0  | 0  | 0          | 0  | 0    | 0  | 0  | 0  | 0  | 0  | 0     | 0  | 0  | 0  |  |

#### Fields

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-28<br>ERSIEN1 | <p>Erase IFR Sector Enable - Block 1 (for dual block configs)</p> <p>This field controls the ability to erase the IFR sectors in block 1 using the ERSSCR command. These bits are loaded from sideband signals during initialization and at launch of ERSSCR command.</p> <p>Note: These bits have no effect on single block configurations. Note: The ERSALL command and MCU mass erase request do not adhere to these restrictions.</p> <p>X equals 0, 1, 2, or 3. Any and all bits in the field are independently configured.</p> <p>0000b - Block 1 IFR Sector X is protected from erase by ERSSCR command</p> <p>0001b - Block 1 IFR Sector X is not protected from erase by ERSSCR command</p> |
| 27-24            | Erase IFR Sector Enable - Block 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ERSIEN0     | <p>This field controls the ability to erase the IFR sectors in block 0 using the ERSSCR command. These bits are loaded from sideband signals during initialization and at launch of ERSSCR command.</p> <p>Note: The ERSALL command and MCU mass erase request do not adhere to these restrictions.</p> <p>X equals 0, 1, 2, or 3. Any and all bits in the field are independently configured.</p> <p>0000b - Block 0 IFR Sector X is protected from erase by ERSSCR command</p> <p>0001b - Block 0 IFR Sector X is not protected from erase by ERSSCR command</p> |
| 23-17<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 16<br>DFDIE | <p>Double Bit Fault Detect Interrupt Enable</p> <p>The DFDIE bit controls interrupt generation when an uncorrectable ECC fault is detected during a valid flash read access from the platform flash controller.</p> <p>0b - Double bit fault detect interrupt disabled</p> <p>1b - Double bit fault detect interrupt enabled. An interrupt request is generated whenever the FSTAT[DFDIF] flag is set.</p>                                                                                                                                                         |
| 15-9<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 8<br>ERSREQ | <p>Mass Erase Request</p> <p>This bit indicates whether a sideband request has been received by the command controller to execute the Mass Erase operation. ERSREQ is not directly writable but sets when a Mass Erase request is received by the flash module while CCIF is set. ERSREQ is cleared by the command controller when the operation completes.</p> <p>0b - No request or request complete</p> <p>1b - Request to run the Mass Erase operation</p>                                                                                                     |
| 7<br>CCIE   | <p>Command Complete Interrupt Enable</p> <p>The CCIE bit controls interrupt generation when a flash command completes.</p> <p>0b - Command complete interrupt disabled</p> <p>1b - Command complete interrupt enabled. An interrupt request is generated whenever the FSTAT[CCIF] flag is set.</p>                                                                                                                                                                                                                                                                 |
| 6-0<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

### 6.6.2.1.4 Flash Control Register (FCTRL)

#### Offset

| Register | Offset |
|----------|--------|
| FCTRL    | 8h     |

#### Function

The flash control register controls activity associated with flash memory reads and command operations.

#### Diagram

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24         | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   |
|-------|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|------|
| R     |    |    |    |    | 0  |    |    | ABTR<br>EQ |    |    |    |    | 0  |    |    |      |
| W     |    |    |    |    |    |    |    | 1          |    |    |    |    |    |    |    | FDFD |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8          | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0    |
| R     |    |    |    |    | 0  |    |    | LSACT      |    |    | 0  |    |    |    |    |      |
| W     |    |    |    |    |    |    |    | IVE        |    |    |    |    |    |    |    | RWSC |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1          | 0  | 0  | 0  | 0  | u  | u  | u  | u    |

#### Fields

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-25<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 24<br>ABTREQ | <p><b>Abort Request</b></p> <p>With FSTAT[CMDP] set, setting the ABTREQ bit allows a user to abort a command write sequence or command operation. The ABTREQ bit can only be set by a user with the same domain ID as indicated by FSTAT[CMDDID] and the same or higher security/privilege protection level than is indicated by FSTAT[CMDPRT]. While ABTREQ is set, CCIF cannot be cleared to launch a command.</p> <p>If FSTAT[CCIF] is high when ABTREQ is set, the command write sequence will abort and ownership transferred to the user setting the ABTREQ bit. The FSTAT[CWSABT] flag will set and the CMDPRT field will be updated based on the write transaction that sets the ABTREQ bit. The ABTREQ bit will then be cleared automatically.</p> <p>If FSTAT[CCIF] is low when ABTREQ is set, the command operation will abort and ownership transferred to the user setting the ABTREQ bit. The FSTAT[CMDABT] flag will set and the CMDPRT field will be updated based on the write transaction that sets the ABTREQ bit. The ABTREQ bit will then be cleared automatically.</p> <p>While CWSABT or CMDABT are high, writes to ABTREQ will be ignored.</p> <p>0b - No request to abort a command write sequence</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | 1b - Request to abort a command write sequence                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 23-17<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 16<br>FDFD    | <p>Force Double Bit Fault Detect</p> <p>The FDFD bit enables the user to emulate the setting of the FSTAT[DFDIF] flag to check the associated interrupt routine. The FDFD bit is cleared by writing a 0 to FDFD.</p> <p>0b - FSTAT[DFDIF] sets only if a double bit fault is detected during a valid flash read access from the platform flash controller</p> <p>1b - FSTAT[DFDIF] sets during any valid flash read access from the platform flash controller. An interrupt request is generated if the DFDIE bit is set.</p>                                                                                                                                                                                                    |
| 15-9<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 8<br>LSACTIVE | <p>Low speed active mode</p> <p>This bit controls entry into the low speed active mode. Flash memory reads are supported in low speed active mode. All flash commands are supported in low speed active mode but the LSACTIVE bit is not writable while a flash command is executing (CCIF=0) or during a non-active power mode. If the FSTAT[CMDP] is set, the protection level of any write transaction to the LSACTIVE bit must match the CMDPRT bits and the domain ID must match the CMDDID bits.</p> <p>Note: If a device does not support low speed active mode, the LSACTIVE bit will reset to 0b and will not be writable.</p> <p>0b - Full speed active mode requested</p> <p>1b - Low speed active mode requested</p> |
| 7-4<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3-0<br>RWSC   | <p>Read Wait-State Control</p> <p>These bits control the number of wait-states added to account for the ratio of system clock period to flash access time during full speed and low speed active power modes. Ratios greater than one require non-zero settings for the RWSC field for proper flash accesses. The required settings are documented in the device data sheet.</p> <p>0h - no additional wait-states are added (single cycle access)</p> <p>1h - 1 additional wait-state is added</p> <p>2h - 2 additional wait-states are added</p> <p>...</p> <p>Fh - 15 additional wait-states are added</p> <p>These bits are loaded from IFR1 during initialization.</p>                                                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                      |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <p style="text-align: center;"><b>NOTE</b></p> <p>The default FCTRL[RWSC] is set to a value appropriate for the chip's max operating frequency. Refer to the chip-specific section for the default value.</p> |

### 6.6.2.1.5 Flash Common Command Object Registers (FCCOB0 - FCCOB7)

#### Offset

For a = 0 to 7:

| Register | Offset         |
|----------|----------------|
| FCCOBa   | 10h + (a × 4h) |

#### Function

The FCCOB register group provides fields for command codes and parameters. The individual words within the set append a 0-7 hex identifier to the FCCOB register name: FCCOB0, FCCOB1, ..., FCCOB7.

#### Diagram



#### Fields

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>CCOBn | <p>CCOBn</p> <p>The FCCOB register group provides a command code and relevant parameters to the command controller. The individual registers that compose the FCCOB data set can be written in any order, but you must provide all needed values, which vary from command to command. First, set up all required FCCOB fields and then initiate the command execution by writing a 1 to the FSTAT[CCIF] bit. This clears the CCIF bit, which locks all FCCOB parameter fields and they cannot be changed by the user until the command completes (CCIF returns to 1). No command buffering or queueing is provided; the next command can be loaded only after the current command completes.</p> |

| Field                     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                           |                                           |   |                                                               |   |                                                                     |   |                         |   |                       |   |             |   |             |   |             |   |             |
|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|-------------------------------------------|---|---------------------------------------------------------------|---|---------------------------------------------------------------------|---|-------------------------|---|-----------------------|---|-------------|---|-------------|---|-------------|---|-------------|
|                           | <p>Some commands return information to the FCCOB registers. Any values returned to FCCOB are available for reading after the FSTAT[CCIF] flag returns to 1.</p> <p>The following table shows a generic flash command format. The first FCCOB register, FCCOB0, always contains the command code. This 8-bit value defines the command to be executed. The command code is followed by the parameters required for this specific flash command, typically an address and/or data values.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>The command parameter table is written in terms of FCCOB Number (which is equivalent to the word number). This number is a reference to the FCCOB register name and is not the register address.</p> <table border="1" style="width: 100%; border-collapse: collapse;"> <thead> <tr> <th style="text-align: left;">FCCOB Number<sup>1</sup></th><th style="text-align: left;">Typical Command Parameter Contents [31:0]</th></tr> </thead> <tbody> <tr> <td>0</td><td>FCMD [7:0] (flash command code, bits [31:8] are not writable)</td></tr> <tr> <td>1</td><td>FCMDOPT [7:0] (flash command options, bits [31:8] are not writable)</td></tr> <tr> <td>2</td><td>Flash address 1 (start)</td></tr> <tr> <td>3</td><td>Flash address 2 (end)</td></tr> <tr> <td>4</td><td>Data Word 0</td></tr> <tr> <td>5</td><td>Data Word 1</td></tr> <tr> <td>6</td><td>Data Word 2</td></tr> <tr> <td>7</td><td>Data Word 3</td></tr> </tbody> </table> <p>1. Refers to FCCOB register name, not register address</p> | FCCOB Number <sup>1</sup> | Typical Command Parameter Contents [31:0] | 0 | FCMD [7:0] (flash command code, bits [31:8] are not writable) | 1 | FCMDOPT [7:0] (flash command options, bits [31:8] are not writable) | 2 | Flash address 1 (start) | 3 | Flash address 2 (end) | 4 | Data Word 0 | 5 | Data Word 1 | 6 | Data Word 2 | 7 | Data Word 3 |
| FCCOB Number <sup>1</sup> | Typical Command Parameter Contents [31:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                           |                                           |   |                                                               |   |                                                                     |   |                         |   |                       |   |             |   |             |   |             |   |             |
| 0                         | FCMD [7:0] (flash command code, bits [31:8] are not writable)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                           |                                           |   |                                                               |   |                                                                     |   |                         |   |                       |   |             |   |             |   |             |   |             |
| 1                         | FCMDOPT [7:0] (flash command options, bits [31:8] are not writable)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                           |                                           |   |                                                               |   |                                                                     |   |                         |   |                       |   |             |   |             |   |             |   |             |
| 2                         | Flash address 1 (start)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                           |                                           |   |                                                               |   |                                                                     |   |                         |   |                       |   |             |   |             |   |             |   |             |
| 3                         | Flash address 2 (end)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                           |                                           |   |                                                               |   |                                                                     |   |                         |   |                       |   |             |   |             |   |             |   |             |
| 4                         | Data Word 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                           |                                           |   |                                                               |   |                                                                     |   |                         |   |                       |   |             |   |             |   |             |   |             |
| 5                         | Data Word 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                           |                                           |   |                                                               |   |                                                                     |   |                         |   |                       |   |             |   |             |   |             |   |             |
| 6                         | Data Word 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                           |                                           |   |                                                               |   |                                                                     |   |                         |   |                       |   |             |   |             |   |             |   |             |
| 7                         | Data Word 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                           |                                           |   |                                                               |   |                                                                     |   |                         |   |                       |   |             |   |             |   |             |   |             |

## 6.7 Glossary

**Block Checker** — MCU IP that provides a mechanism to set access rights to the flash memory for read and write operations.

**Command write sequence** — A series of MCU writes to the Flash FCCOB register group and FSTAT[CCIF] that initiates and controls the execution of flash algorithms that are built into the flash module.

**Endurance** — The number of times that an aligned flash or IFR phrase can be erased and reprogrammed.

**FCCOB (Flash Common Command Object Block)** — A group of flash registers that are used to pass command, address, data, and any associated parameters to the command controller.

**Flash block** — A macro within the flash module which provides the nonvolatile memory storage with an aligned block address being the first address in the block.

**Flash module** — All flash blocks plus a flash management unit providing command control and an interface to MCU buses.

**Flash page** — 128 bytes of flash main memory with an aligned page having byte-address[6:0] = 00h; represents the largest portion of the flash memory that can be programmed in one operation.

**Flash phrase** — 16 bytes of flash main memory with an aligned phrase having byte-address[3:0] = 0000b; represents the smallest portion of the flash memory that can be programmed in one operation.

**Flash sector** — 8 Kbytes of flash main memory with an aligned sector having byte-address[12:0] = 0000h; represents the smallest portion of the flash memory that can be erased in one operation.

**FLW** — The Flash Logical Window module allows a specific logical address range to access a programmable physical address range in the flash memory with programmable FLW default settings stored in IFR space.

**FMC** — Flash Memory Controller module manages flash memory reads and writes.

**IFR** — Information flash region separate from the main flash memory array. Each flash block has 32 Kbytes of user IFR space. Sometimes referred to as IFR0.

**IFR1** — Information flash region separate from the main memory array reserved for array trim, MCU trim, and test. Each flash array has 8 Kbytes of IFR1 space.

**IFR page** — 128 bytes of IFR or IFR1 space with an aligned IFR page having byte-address[6:0] = 00h; represents the largest portion of IFR space that can be programmed.

**IFR phrase** — 16 bytes of IFR or IFR1 space with an aligned IFR phrase having byte-address[3:0] = 0000b; represents the smallest portion of IFR space that can be programmed in one operation.

**IFR sector** — 8 Kbytes of IFR or IFR1 space with an aligned IFR sector having byte-address[12:0] = 0000h; represents the smallest portion IFR space that can be erased.

**MISR** — Multiple-input signature register used to generate a signature based on flash memory contents read.

**MSF** — Microcontroller Secure Flash.

**NVM** — Nonvolatile memory. The flash block is an NVM using NOR-type flash memory technology.

**Program flash** — Program flash memory provides nonvolatile storage for vectors and code store.

**Retention** — The length of time that data (erased or programmed) can be kept in the NVM without experiencing errors upon readout.

**Security/Privilege protection levels** — The Flash module supports 4 levels of security/privilege protection for flash commands:

1. Secure (Trusted) / Privileged
2. Secure (Trusted) / User
3. Non-secure (Non-Trusted) / Privileged
4. Non-secure (Non-Trusted) / User

# Chapter 7

## Flash Memory Controller (FMC)

### 7.1 Chip-specific FMC information

Table 54. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | FMC            | <a href="#">FMC</a>                 |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

See [NVM Control \(NVM\\_CTRL\)](#) for details on flash speculation and flash cache control.

#### 7.1.1 Module instances

This device has one instance of the FMC module, FMC0.

## 7.2 Overview

The Flash Memory Controller (FMC) is a memory interface and acceleration unit providing:

- An interface between the device and the nonvolatile memory
- Buffers that can accelerate flash memory transfers

The FMC manages the interface between the device and the flash memory. The FMC receives status information describing the configuration of the memory and uses this information to ensure a proper interface. The next table shows the supported read/write operations.

| Flash memory type               | Read                            | Write                       |
|---------------------------------|---------------------------------|-----------------------------|
| Program, IFR, IFR1 flash memory | 8-bit, 16-bit, and 32-bit reads | 16-byte and 128-byte writes |

The FMC provides quick access to flash memory using separate acceleration mechanisms:

- A flash-phrase-sized buffer holds the most recently accessed flash phrase
- An optional flash-phrase-sized speculation buffer can prefetch the next flash phrase

The FMC is controlled by a programmer's model external to the FMC module; see the chip-specific FMC information for details. The FMC's programming model provides a very configurable, high performance flexible memory controller, which can be optimized for the runtime characteristics of specific applications.

#### NOTE

Program the FMC's controls only while the flash controller is idle. Changing the configuration settings while a flash access is in progress can cause non-deterministic, unpredictable behavior.

### 7.2.1 Features

- Interface between the device and the flash memory:
  - The FMC's input bus supports 8-bit, 16-bit, and 32-bit read operations to flash memory.

- The FMC's flash memory interface fetches a 128-bit flash phrase.
  - For input read requests, the FMC fetches a flash phrase with the desired read data from flash memory.
  - The FMC's flash memory interface can write aligned 16-byte flash write phrases or aligned 128-byte flash write pages to flash memory.
  - The FMC has a 16-byte aligned write buffer, used once for aligned 16-byte flash write phrases or used 8 times for aligned 128-byte flash write pages.
  - The FMC's input bus supports 32-bit write operations for flash memory writes to fill the FMC's write buffer.
  - For input write requests, the FMC must receive the 4-word write of an aligned phrase in order.
- Acceleration of data transfer from flash memory to the device:
    - A flash-phrase-sized buffer that holds the current decrypted flash phrase fetched due to a FMC read request. Subsequent FMC read requests *that hit in the current buffer* return data with no wait states.
    - A flash-phrase-sized prefetch speculation buffer with controls for prefetching on instructions and/or data reads. When prefetching is enabled, idle FMC-to-flash interface cycles are used to fetch the next sequential flash phrase and hold it in the prefetch buffer. Subsequent FMC read requests *that hit in the speculation buffer* return data with no wait states.
    - Input controls:
      - to disable data type speculation
      - to disable all speculation
      - to invalidate the current and speculation buffers

---

**NOTE**

Clear the speculation buffer before accessing recently modified flash addresses. To clear the speculation buffer, first disable then re-enable the speculation.

---

## 7.3 Functional description

The FMC is a flash interface and acceleration unit, with flexible buffers for user configuration.

- The FMC's input bus can operate faster than the flash memory.
- The FMC-to-flash interface has flow control to add wait states as needed (for input bus reads that need flash accesses).
- The FMC also contains various configurable buffers that hold recent flash accesses. If an input bus read hits a valid buffer, then that access will complete with no wait states.

### 7.3.1 Modes of operation

The FMC only operates when a bus master accesses the flash memory.

For any device power mode where the flash memory cannot be accessed, the FMC is disabled.

### 7.3.2 Default configuration

After system reset, the FMC is configured to provide a significant level of buffering for transfers from the flash memory. For all banks:

- The current and speculation buffers are cleared by reset.
- Prefetch support for data and instructions is enabled.

### 7.3.3 Configuration options

The default configuration provides a high degree of flash acceleration, however, advanced users may want to customize the FMC buffer configurations, to maximize throughput for their use cases. When reconfiguring the FMC for custom use cases, do not

program the FMC's control registers while the flash memory is being accessed. Instead, change the control registers with a routine executing from RAM in supervisor mode.

The FMC's buffering controls allow the tuning of resources to suit specific application requirements. The buffer are each controlled individually. The controls enable buffering and prefetching per access type (instruction fetch or data reference).

As an application example: if both instruction fetches and data references are accessing flash memory, then control is available to send instruction fetches, data references, or both to the single-entry buffer. Likewise, speculation can be enabled or disabled for either type of access.

### 7.3.4 Wait states

Because the core, crossbar switch, and bus masters can be clocked at a higher frequency than the flash clock, flash memory accesses that do not hit in the speculation buffer usually require wait states.

FMC does not allow the configuration of wait states directly. Wait states can be controlled via FMU FCTRL[RWSC].

### 7.3.5 Speculative reads

The FMC has a single buffer that reads ahead to the next phrase in the flash memory if there is an idle cycle. Speculative prefetching is programmable for instruction and data accesses. Because many code accesses are sequential, using the speculative prefetch buffer improves performance in most cases.

Speculative reads can be controlled via System Controller NVM\_CTRL. Besides NVM\_CTRL[DIS\_DATA\_SPEC] and NVM\_CTRL[DIS\_FLASH\_SPEC], NVM\_CTRL[DIS\_MBECC\_ERR\_INST] and NVM\_CTRL[DIS\_MBECC\_ERR\_DATA] can enable and disable speculative reads separately.

When speculative reads are enabled, the FMC immediately requests the next sequential phrase address after a read completes. By requesting the next phrase immediately, speculative reads can help to reduce or even eliminate wait states when accessing sequential code and/or data.

### 7.3.6 Remapping flash addresses

An address remap mechanism allows for the swapping (both ways) of a specified flash address range between the lower half and the upper half of flash memory. This remapping can facilitate software updates in the field without the need for address modifications in software. For example, to use the remap mechanism to update software in the lower portion of bank 0, follow these steps:

1. Load the updated software into the upper half of flash.
2. Enable remapping to automatically use the updated software.

In **REMAP**, remapping is enabled when LIM[20:16] = LIMDP[28:24], and LIM[20:16] is nonzero. LIM[20:16] and LIMDP[28:24] define the *remap\_address[17:13]* for the remapping, providing an address range granularity of 8 KB. For a remapped FMC access to address *access\_address*, see [Table 55](#).

**Table 55. Remapping *access\_address***

| When <i>access_address</i> originates in... | And is less than or equal to...                        | The access remaps to...                          | In...            |
|---------------------------------------------|--------------------------------------------------------|--------------------------------------------------|------------------|
| flash lower half                            | <i>remap_address[17:13]</i>                            | flash upper half base +<br><i>access_address</i> | flash upper half |
| flash upper half                            | flash upper half base +<br><i>remap_address[17:13]</i> | <i>access_address</i> – flash upper<br>half base | flash lower half |

The address ranges that may be swapped depends on the total flash size available. For non-power-of-2 total flash sizes, the upper half of flash bank 0 cannot be swapped, as shown in [Table 56](#).

**Table 56. Remapping address ranges**

| For a flash size of... | This lower half flash range... | Remaps to this upper half flash range... | This lower half flash range cannot be remapped... |
|------------------------|--------------------------------|------------------------------------------|---------------------------------------------------|
| 128 KB                 | 0x0_0000 – 0x0_FFFF            | 0x1_0000 – 0x1_FFFF                      | —                                                 |
| 96 KB                  | 0x0_0000 – 0x0_7FFF            | 0x1_0000 – 0x1_7FFF                      | 0x0_8000 – 0x0_FFFF                               |
| 64 KB                  | 0x0_0000 – 0x0_7FFF            | 0x0_8000 – 0x0_FFFF                      | —                                                 |
| 48 KB                  | 0x0_0000 – 0x0_3FFF            | 0x0_8000 – 0x0_BFFF                      | 0x0_4000 – 0x0_7FFF                               |
| 32 KB                  | 0x0_0000 – 0x0_3FFF            | 0x0_4000 – 0x0_7FFF                      | —                                                 |

When LIM = LIMDP = 0, FMC disables the remap function. When LIM = LIMDP = a nonzero value, the remapping address range is  $(LIM + 1) \times 8$  KB. For example:

- When LIM = LIMDP = 1, the range is  $\leq 16$  KB.
- When LIM = LIMDP = 2, the range is  $\leq 32$  KB.

### 7.3.7 Interrupts

This module has no interrupts.

## 7.4 External signals

The FMC has no external signals.

## 7.5 Initialization and application information

The FMC does not require user initialization. Flash acceleration features are enabled by default.

The FMC has no visibility into flash memory erase and program cycles because the Flash Memory module manages them directly. As a result, if an application is executing flash memory commands, the FMC's current buffer and speculation buffer might need to be disabled and/or flushed to prevent the possibility of returning stale data.

## 7.6 Register descriptions

It has a Flash Remap Control register.

#### NOTE

See the chip-specific information for FMC controls.

#### NOTE

Any access to an undefined memory area results in a bus error.

### 7.6.1 NPX register descriptions

#### 7.6.1.1 NPX memory map

FMC0 base address: 4009\_4000h

| Offset | Register           | Width<br>(In bits) | Access | Reset value |
|--------|--------------------|--------------------|--------|-------------|
| 20h    | Data Remap (REMAP) | 32                 | RW     | 0000_0000h  |

### 7.6.1.2 Data Remap (REMAP)

#### Offset

| Register | Offset |
|----------|--------|
| REMAP    | 20h    |

#### Function

Provides a data remapping mechanism.

To write to REMAP, the remap lock must be disabled (REMAPLK = 0). To control the remapping, follow these options:

- To write to LIMDP, write 0xNNNNA5A5 (where NNNN is data) to REMAP. In this case, bits 28 to 24 are written to LIMDP. All other fields of REMAP remain unchanged.
- To write to LIM, write 0xNNNN5A5A (where NNNN is data) to REMAP. In this case, bits 20 to 16 are written to LIM.
- Any other writes to REMAP are ignored.

#### Diagram



#### Fields

| Field | Function                                                                                               |
|-------|--------------------------------------------------------------------------------------------------------|
| 31-29 | Always reads as 0. When writing, see the register description above.                                   |
| —     |                                                                                                        |
| 28-24 | LIMDP Remapping Address                                                                                |
| LIMDP | Defines remap_address[17:13] for remapping. Its value should be lower than the lower-half flash range. |
| 23-21 | Always reads as 0. When writing, see the register description above.                                   |
| —     |                                                                                                        |
| 20-16 | LIM Remapping Address                                                                                  |
| LIM   | Defines remap_address[17:13] for remapping. Its value should be lower than the lower-half flash range. |
| 15-1  | Always reads as 0. When writing, see the register description above.                                   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                               |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —            |                                                                                                                                                                                                                                                                                                        |
| 0<br>REMAPLK | <p>Remap Lock Enable</p> <p>To set the remap lock, write 0xFFFFC3C3 (X = don't care) to REMAP. All other fields of REMAP remain unchanged.</p> <p>Set by software (sticky); cleared only by a reset.</p> <p>0b - Lock disabled: can write to REMAP</p> <p>1b - Lock enabled: cannot write to REMAP</p> |

# Chapter 8

## Error Injection Module (EIM)

### 8.1 Chip-specific EIM information

Table 57. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | EIM            | <a href="#">EIM</a>                 |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 8.1.1 Module instances

This device contains one instance of the Error Injection module, EIM0.

#### 8.1.2 EIM channel mapping

This chip implements the EIM module for ECC RAM. It can inject error when read ECC RAM. It can be used for self-test. Only RAM A0 supports ECC on this device. EIM channel 0 is used to inject ECC error to RAM A0. See the functional block diagram of EIM in the following figure.



Figure 11. EIM functional block diagram

## 8.2 Overview

The Error Injection Module (EIM) is mainly used for diagnostic purposes. It provides a method to test the diagnostics (memory ECC, interconnect parity) by error injection in the field. See the chip-specific EIM information to determine which functional safety features are supported by this method.

EIM enables you to inject artificial errors on error-checking mechanisms of a system, such as ECC for RAM read data and parity bits. For each such mechanism that EIM supports on the chip, EIM can inject single-bit and multi-bit inversions on data in the applicable target bus. Injecting faults on memory accesses can be used to exercise the SEC-DED ECC function of the related system.

### 8.2.1 Features

The EIM includes these features:

- Supports 1 error injection channel. See the chip-specific EIM information for channel assignment details.
- Protection against accidental enable and reconfiguration error injection function via two-stage enable mechanism

### 8.2.2 Block diagram

The following diagram shows an example of EIM implementation with a 64-bit read data bus and an 8-bit checkbit bus.



Figure 12. EIM functional block diagram (64-bit read data bus and 8-bit check bit bus)

Several memory elements are implemented within a device, which may not only be the large memory blocks (Flash and SRAM) but also smaller memories like caches, the TCD blocks, and the embedded peripheral memories. Some larger memories may actually be built from multiple memory elements, dependent on their size or function. Each of these memory elements implements its own control logic, the memory controller, that performs the accesses to the actual memory, the memory array. An EIM channel is associated with a memory controller and provides the capability to alter one or multiple signals in the read access path from the corresponding memory array(s). Only memory controllers controlling a safety related memory may be associated with an EIM channel.

## 8.3 Functional description

The EIM provides protection against accidental enabling and reconfiguration of the error injection function by enforcing a two-stage enablement mechanism. To properly enable the error injection mechanism for a channel:

- Write 1 to the EICHEN[EICH $n$ EN] field, where  $n$  denotes the channel number.
- Write 1 to EIMCR[GEIEN].

---

### NOTE

When the use case for a channel requires writing any EICHD $n$ \_WORD register, write the EICHD $n$ \_WORD register before executing the two-stage enablement mechanism. A successful write to any EICHD $n$ \_WORD register clears the corresponding EICHEN[EICH $n$ EN] field.

The EIM supports 1 error injection channel. See the chip-specific EIM information for channel assignment details. Each channel:

- Can be assigned to a single memory array interface by intercepting the assigned memory read data bus and checkbit bus, and injects errors by inverting the value transmitted for selected bits on each bus line.
- Can be assigned to a redundant comparison unit by intercepting the signals being compared, and injecting errors by inverting the value transmitted for selected bits on each bus line.

On a memory read access, the applicable EICHD $n$ \_WORD registers define which bits of the read data and/or checkbit bus to invert.

Figure 12 depicts the interception and override of a 64-bit read data bus and an 8-bit checkbit data bus for an example memory array.

### Error injection scenarios

The EIM supports these cases of error injection:

- To generate a single-bit error, invert only 1 bit of the CHKBIT\_MASK or DATA\_MASK in the EICHD $n$ \_WORD registers.
- To generate a multi-bit error, invert only 2 bits of the CHKBIT\_MASK or DATA\_MASK in the EICHD $n$ \_WORD registers.

---

### NOTE

An attempt to invert more than 2 bits in one operation might result in undefined behavior.

To enable error injection:

1. Set the EICHD $n$ \_WORD $m$ [CHKBIT\_MASK] and EICHD $n$ \_WORD $m$ [Ba\_bDATA\_MASK] fields for each channel that will be driving an injection.
2. Program the EICHEN register to enable the channels that will be injecting errors.
3. Set the EIMCR[GEIEN] field to globally allow all enabled channels to actively inject errors.

To disable error injection, either disable the EIMCR[GEIEN] field or disable the individual channel enable fields of the EICHEN register.

## 8.4 Initialization

This module does not require initialization.

## 8.6 EIM register descriptions

The EIM provides a programming model mapped to an on-platform peripheral slot.

### Programming model access

All system bus masters can access the programming model:

- Only in supervisor mode

- Using only 32-bit (word) accesses

Any of the following attempted references to the programming model generates an error termination:

- In user mode
- Using non-32-bit access sizes
- To undefined (reserved) addresses

Attempted updates to the programming model while the EIM is in the midst of an operation result in non-deterministic behavior.

#### Error injection channel descriptor: function and structure

Each error injection channel descriptor:

- Specifies a mask that defines which bits of the read data and/or checkbit bus from target RAM are inverted on a read access.
- Consists of a 128-bit (16-byte) structure, composed of four 32-bit words, in the EIM programming model. Unused words are not documented.
  - Word0 (EICHD $n$ \_WORD0), if present, defines the checkbit mask.
  - Word1-3 (EICHD $n$ \_WORD1-3), if present, define the data mask. Word2 and Word3 are present only when required by the total width of the channel's data mask. See Error injection channel descriptor: DATA\_MASK details.

#### Error injection channel descriptor: DATA\_MASK details

The following table shows the total width of DATA\_MASK and the distribution of its bits across the WORD registers.

Table 58. Error injection channel descriptor: DATA\_MASK details

| Channel | DATA_MASK total width (bits) | Specific bits of DATA_MASK in |       |       |
|---------|------------------------------|-------------------------------|-------|-------|
|         |                              | WORD1                         | WORD2 | WORD3 |
| 0       | 32                           | 31-0                          | —     | —     |

#### 8.6.1 EIM memory map

EIM0 base address: 4008\_C000h

| Offset | Register                                                   | Width (In bits) | Access | Reset value |
|--------|------------------------------------------------------------|-----------------|--------|-------------|
| 0h     | Error Injection Module Configuration Register (EIMCR)      | 32              | RW     | 0000_0000h  |
| 4h     | Error Injection Channel Enable register (EICHEN)           | 32              | RW     | 0000_0000h  |
| 100h   | Error Injection Channel Descriptor 0, Word0 (EICHD0_WORD0) | 32              | RW     | 0000_0000h  |
| 104h   | Error Injection Channel Descriptor 0, Word1 (EICHD0_WORD1) | 32              | RW     | 0000_0000h  |

#### 8.6.2 Error Injection Module Configuration Register (EIMCR)

Offset

| Register | Offset |
|----------|--------|
| EIMCR    | 0h     |

**Function**

The EIM Configuration Register is used to globally enable/disable the error injection function.

**Diagram**

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

**Fields**

| Field      | Function                                                                                                                                                                                                         |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-1<br>—  | Reserved                                                                                                                                                                                                         |
| 0<br>GEIEN | <p>Global Error Injection Enable</p> <p>This bit globally enables or disables the error injection function of the EIM. This field is initialized by hardware reset.</p> <p>0b - Disabled</p> <p>1b - Enabled</p> |

**8.6.3 Error Injection Channel Enable register (EICHEN)****Offset**

| Register | Offset |
|----------|--------|
| EICHEN   | 4h     |

**Function**

Each field of the Error Injection Channel Enable register (EICHEN) is used to enable or disable the corresponding error injection channel.

**NOTE**

To enable an error injection channel, the Global Error Injection Enable (EIMCR[GEIEN]) field must also be asserted.

**Diagram**

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

**Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>EICHOEN | Error Injection Channel 0 Enable<br><br>This field enables the corresponding error injection channel. The Global Error Injection Enable (EIMCR[GEIEN]) field must also be asserted to enable error injection.<br><br>After error injection is enabled, all subsequent read accesses incur one or more bit inversions as defined in the corresponding EICHD $n$ _WORD registers. Error injection remains in effect until the error injection channel is manually disabled via software.<br><br>Any write to the corresponding EICHD $n$ _WORD registers clears the corresponding EICHEN[EICH $n$ EN] field, disabling the error injection channel.<br><br>0b - Error injection is disabled on Error Injection Channel 0<br>1b - Error injection is enabled on Error Injection Channel 0 |
| 30<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 29<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 28<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 27<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 26<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 25<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function |
|-------|----------|
| 24    | Reserved |
| —     |          |
| 23    | Reserved |
| —     |          |
| 22    | Reserved |
| —     |          |
| 21    | Reserved |
| —     |          |
| 20    | Reserved |
| —     |          |
| 19    | Reserved |
| —     |          |
| 18    | Reserved |
| —     |          |
| 17    | Reserved |
| —     |          |
| 16    | Reserved |
| —     |          |
| 15    | Reserved |
| —     |          |
| 14    | Reserved |
| —     |          |
| 13    | Reserved |
| —     |          |
| 12    | Reserved |
| —     |          |
| 11    | Reserved |
| —     |          |
| 10    | Reserved |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function |
|-------|----------|
| —     |          |
| 9     | Reserved |
| —     |          |
| 8     | Reserved |
| —     |          |
| 7     | Reserved |
| —     |          |
| 6     | Reserved |
| —     |          |
| 5     | Reserved |
| —     |          |
| 4     | Reserved |
| —     |          |
| 3     | Reserved |
| —     |          |
| 2     | Reserved |
| —     |          |
| 1     | Reserved |
| —     |          |
| 0     | Reserved |
| —     |          |

#### 8.6.4 Error Injection Channel Descriptor 0, Word0 (EICH0\_WORD0)

##### Offset

| Register    | Offset |
|-------------|--------|
| EICH0_WORD0 | 100h   |

##### Function

The first word of the Error Injection Channel Descriptor defines a left-justified mask field: CHKBIT\_MASK. Each bit of CHKBIT\_MASK specifies whether the corresponding bit of the checkbit bus from the target RAM should be inverted or

remain unmodified on read accesses. Successful write to this field clears the corresponding error injection channel valid bit, EICHEN[EICH $n$ EN].

### Diagram

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

### Fields

| Field                | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-25<br>CHKBIT_MASK | <p>Checkbit Mask</p> <p>This field defines a bit-mapped mask that specifies whether the corresponding bit of the checkbit bus from the target RAM should be inverted or remain unmodified. Writes to unimplemented bits are ignored.</p> <p>For any unique details about the mapping of CHKBIT_MASK's bits to a channel's target RAM, see the chip-specific EIM information.</p> <p><b>NOTE</b></p> <p>Because CHKBIT_MASK is left-justified, the highest bit in the bit range is always in the position of the most significant bit. For CHKBIT_MASK[6:0] (7 bits wide), CHKBIT_MASK[6] is in the position of the most significant bit.</p> <p>0b - The corresponding bit of the checkbit bus remains unmodified.<br/>1b - The corresponding bit of the checkbit bus is inverted.</p> |
| 24-0<br>—            | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

### 8.6.5 Error Injection Channel Descriptor 0, Word1 (EICHD0\_WORD1)

#### Offset

| Register     | Offset |
|--------------|--------|
| EICHD0_WORD1 | 104h   |

#### Function

The second word of the Error Injection Channel Descriptor defines a right-justified mask field. The bits in B0\_3DATA\_MASK correspond to bytes 0–3 of the target bus. Each bit specifies whether the corresponding bit of the target bus should be inverted

or remain unmodified on read accesses. A successful write to this field clears the corresponding error injection channel valid field, EICHEN[EICH $n$ EN].

### Diagram

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

### Fields

| Field                     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>B0_3DATA_MAS<br>K | <p>Data Mask Bytes 0-3</p> <p>This field defines a bit-mapped mask that specifies whether the corresponding bit of the read data bus from the target RAM should be inverted or remain unmodified. Writes to unimplemented bits are ignored.</p> <p><b>NOTE</b></p> <p>For the specific DATA_MASK bits to which B0_3DATA_MASK corresponds, See Error injection channel descriptor: DATA_MASK details.</p> <p>0b - The corresponding bit of bytes 0-3 on the read data bus remains unmodified.<br/>1b - The corresponding bit of bytes 0-3 on the read data bus is inverted.</p> |

# Chapter 9

## Error Reporting Module (ERM)

### 9.1 Chip-specific ERM information

Table 59. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | ERM            | <a href="#">ERM</a>                 |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 9.1.1 Module instances

This device contains one instance of the Error Recording module, ERM0.

#### 9.1.2 ERM channel mapping

ERM can record the address and ECC check bits (errs syndrome), when ECC error happens. ERM can be configured to generate interrupt when single bit or multi bit error happens. The error address, ECC check bits and ECC error outputs of SECDED should be connected to ERM.

Table 60. ERM channel mapping

| Channel no. | Module | Captured status                                                  |
|-------------|--------|------------------------------------------------------------------|
| 0           | RAM A0 | Single-bit error, multiple bit error, error address syndrome     |
| 1           | FMU0   | ECC double-bit error detected on read data from array to the FMC |

#### 9.1.3 ERM Memory a Error Address Register

The "ERM Memory a Error Address Register" provides the offset of error location and not the absolute address. For example, if memory is SRAM0 (which starts from 0x20400000) if error occurs at 0x20400010 the EAR register gives value 0x10 and not 0x20400010.

## 9.2 Overview

The Error Reporting Module (ERM) provides information and optional interrupt notification on memory error events associated with ECC and parity. The ERM collects error events on memory accesses for memory arrays, such as flash memory, system RAM, or peripheral RAMs. ERM supports various channels for memory sources where each ERM channel is associated with a different memory module. See the chip-specific ERM information for details about supported memory sources and specific memory channel assignments. If the memory supports ECC, then ERM syndrome and error address information is captured along with the error event. ERM does not capture syndrome or error address for cache memories or memory with parity instead of ECC.

### 9.2.1 Features

The ERM includes these features:

- Optional interrupt notification on captured error events
- Capturing of address and syndrome information on single-bit correction and non-correctable ECC events
- Support for error event capturing for memory sources, with individual reporting fields and interrupt configuration per memory channel
- Recording the count value of the number of corrected error events

### 9.2.2 Block diagram



Figure 13. Block diagram

## 9.3 Functional description

### 9.3.1 Single-bit correction events

When a single-bit correction event on Memory  $n$  is detected, the ERM:

- Records the event by changing the value of the applicable Status Register bit  $SRx[SBC_n]$  to 1.
- Increments the correctable error count value (until the counter reaches its maximum value):  $CORR\_ERR\_CNT_n[COUNT]$ .
- Records the corresponding access address that initiated the event in the Memory  $n$  Error Address Register:  $EAR_n$  (if this register is present for the channel).

- Stores the corresponding ECC syndrome in the Memory  $n$  Error Syndrome Register: SYN $n$  (if this register is present for the channel). This register identifies the bit position of the corrected data on single-bit data inversion.

The ERM holds event information only for the last reported event.

To clear the record of an event, write 1 to SRx[SBC $n$ ] to change its value to 0.

To reset the correctable error count value, write all zeros to CORR\_ERR\_CNT $n$ [COUNT].

#### Optional interrupt notification for single-bit correction events

The ERM provides an option to generate an interrupt notification upon the report of a single-bit correction event. To enable single-bit correction interrupts for a channel:

1. To enable interrupt notification for single-bit correction events on Memory  $n$ , set CRx[ESCIEn] to 1.
2. Subsequently, when a single-bit correction event on Memory  $n$  is detected, the ERM:
  - Records the event and address, and stores the ECC syndrome as usual.
  - Additionally sends an interrupt notification corresponding to the event.
3. To clear both the record of an event and the corresponding interrupt notification, write 1 to SRx[SBC $n$ ] to change its value to 0.

#### 9.3.2 Non-correctable error events

When a non-correctable ECC error event on Memory  $n$  is detected, the ERM:

- Records the event by changing the value of the applicable Status Register bit: SRx[NCE $n$ ] to 1.
- Records the corresponding access address that initiated the event in the Memory  $n$  Error Address Register: EAR $n$  (if this register is present for the channel).
- Stores the corresponding ECC syndrome in the Memory  $n$  Error Syndrome Register: SYN $n$  (if this register is present for the channel).
  - In the event of a non-correctable address bit inversion, SYN $n$  identifies the pertinent address bit position.
  - In the event of a non-correctable, multi-bit data inversion, the syndrome value does not provide any additional diagnostic information.

The ERM holds event information only for the last reported event.

To clear the record of an event, write 1 to SRx[NCE $n$ ] to change its value to 0.

#### Optional interrupt notification for non-correctable error events

The ERM provides an option to generate an interrupt notification upon the report of a non-correctable ECC event. To enable non-correctable error interrupts for a channel:

1. To enable interrupt notifications for non-correctable error events on Memory  $n$ , set CRx[ENCIEn] to 1.
2. Subsequently, when a non-correctable error event on Memory  $n$  is detected, the ERM:
  - Records the event and address and stores the ECC syndrome as usual.
  - Additionally sends an interrupt notification corresponding to the event.
3. To clear both the record of an event and the corresponding interrupt notification, write 1 to SRx[NCE $n$ ] to change its value to 0.

#### NOTE

Parity errors can be mapped to non-correctable errors where error attributes like SYNDROME, ADDRESS are not provided.

## 9.4 Initialization

For each ERM channel supporting memory with ECC, prepare the corresponding memory array before enabling ERM interrupts about errors for that memory.

1. Initialize the memory to a known value so that the correct corresponding ECC codeword is stored.
2. During the memory's initialization, if the ERM captures information about any ECC error event, clear the corresponding SRx[SBC $n$ ] or SRx[NCE $n$ ] field that stores the record of the event.
3. Program the applicable CRx[ESCIEn] and CRx[ENCIEn] fields to enable ERM interrupts as desired.

## 9.5 ERM register descriptions

You can access the programming model:

- Only in supervisor mode
- Using only 32-bit (word) accesses

Any of the following attempted references to the programming model generates an error termination:

- In user mode
- Using non-32-bit access sizes

Based on the design implementation, the following XFR error behavior is evident at the IPS interface.

- Within the ERM memory map, an XFR error is evident at reserved addresses from location 20h to FFh.
- No XFR error is evident at reserved addresses in memory spaces allocated to each channel. For example: For channel 0, for read/write accesses to reserved address 10Ch, the XFR error is 0.
- For accesses to locations beyond the addresses allocated for the final channel, the XFR error is 1.

---

### NOTE

- See the chip-specific ERM information at the beginning of this chapter for details on Memory channel mapping.
  - To access the channel registers, corresponding memory channel clock must be enabled.
- 

### 9.5.1 ERM memory map

ERM0 base address: 4008\_D000h

| Offset | Register                                                      | Width<br>(in bits) | Access | Reset value |
|--------|---------------------------------------------------------------|--------------------|--------|-------------|
| 0h     | ERM Configuration Register 0 (CR0)                            | 32                 | RW     | 0000_0000h  |
| 10h    | ERM Status Register 0 (SR0)                                   | 32                 | RW     | 0000_0000h  |
| 100h   | ERM Memory 0 Error Address Register (EAR0)                    | 32                 | R      | 0000_0000h  |
| 104h   | ERM Memory 0 Syndrome Register (SYN0)                         | 32                 | R      | 0000_0000h  |
| 108h   | ERM Memory 0 Correctable Error Count Register (CORR_ERR_CNT0) | 32                 | RW     | 0000_0000h  |
| 118h   | ERM Memory 1 Correctable Error Count Register (CORR_ERR_CNT1) | 32                 | RW     | 0000_0000h  |

### 9.5.2 ERM Configuration Register 0 (CR0)

#### Offset

| Register | Offset |
|----------|--------|
| CR0      | 0h     |

#### Function

This 32-bit control register configures the interrupt notification capability for available channels.

#### Diagram

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

#### Fields

| Field        | Function                                                                                                                                                                                                                                    |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>ESCIE0 | ESCIE0<br>Enable Memory 0 Single Correction Interrupt Notification<br>0b - Interrupt notification of Memory 0 single-bit correction events is disabled.<br>1b - Interrupt notification of Memory 0 single-bit correction events is enabled. |
| 30<br>ENCIE0 | ENCIE0<br>Enable Memory 0 Non-Correctable Interrupt Notification<br>0b - Interrupt notification of Memory 0 non-correctable error events is disabled.<br>1b - Interrupt notification of Memory 0 non-correctable error events is enabled.   |
| 29-28<br>—   | Reserved                                                                                                                                                                                                                                    |
| 27<br>ESCIE1 | ESCIE1<br>Enable Memory 1 Single Correction Interrupt Notification<br>0b - Interrupt notification of Memory 1 single-bit correction events is disabled.                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                  |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | 1b - Interrupt notification of Memory 1 single-bit correction events is enabled.                                                                                                                                                          |
| 26<br>ENCIE1 | ENCIE1<br>Enable Memory 1 Non-Correctable Interrupt Notification<br>0b - Interrupt notification of Memory 1 non-correctable error events is disabled.<br>1b - Interrupt notification of Memory 1 non-correctable error events is enabled. |
| 25-24<br>—   | Reserved                                                                                                                                                                                                                                  |
| 23-22<br>—   | Reserved                                                                                                                                                                                                                                  |
| 21-20<br>—   | Reserved                                                                                                                                                                                                                                  |
| 19-18<br>—   | Reserved                                                                                                                                                                                                                                  |
| 17-16<br>—   | Reserved                                                                                                                                                                                                                                  |
| 15-14<br>—   | Reserved                                                                                                                                                                                                                                  |
| 13-12<br>—   | Reserved                                                                                                                                                                                                                                  |
| 11-10<br>—   | Reserved                                                                                                                                                                                                                                  |
| 9-8<br>—     | Reserved                                                                                                                                                                                                                                  |
| 7-6<br>—     | Reserved                                                                                                                                                                                                                                  |
| 5-4<br>—     | Reserved                                                                                                                                                                                                                                  |
| 3-2<br>—     | Reserved                                                                                                                                                                                                                                  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function |
|-------|----------|
| 1-0   | Reserved |
| —     |          |

### 9.5.3 ERM Status Register 0 (SR0)

#### Offset

| Register | Offset |
|----------|--------|
| SR0      | 10h    |

#### Function

This 32-bit status register reports error events for available channels.

#### Diagram

| Bits  | 31   | 30   | 29 | 28 | 27   | 26   | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------|------|----|----|------|------|----|----|----|----|----|----|----|----|----|----|
| R     | SBC0 | NCE0 | 0  |    | SBC1 | NCE1 | 0  |    | 0  |    |    |    | 0  |    | 0  |    |
| W     | W1C  | W1C  |    |    | W1C  | W1C  |    |    |    |    |    |    |    |    |    |    |
| Reset | 0    | 0    | 0  | 0  | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bits  | 15   | 14   | 13 | 12 | 11   | 10   | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     | 0    |      |    |    | 0    |      |    |    | 0  |    |    |    | 0  |    |    |    |
| W     |      |      |    |    |      |      |    |    |    |    |    |    |    |    |    |    |
| Reset | 0    | 0    | 0  | 0  | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

#### Fields

| Field      | Function                                                                                                                                                                                                                                                                                        |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>SBC0 | SBC0<br>Memory 0 Single-Bit Correction Event<br>Write 1 to clear this field. This write also clears the corresponding interrupt notification, if CR0[ESCIE0] is enabled.<br>0b - No single-bit correction event on Memory 0 detected.<br>1b - Single-bit correction event on Memory 0 detected. |
| 30<br>NCE0 | NCE0<br>Memory 0 Non-Correctable Error Event                                                                                                                                                                                                                                                    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                         |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | <p>Write 1 to clear this field. This write also clears the corresponding interrupt notification, if CR0[ENCIE0] is enabled.</p> <p>0b - No non-correctable error event on Memory 0 detected.<br/>1b - Non-correctable error event on Memory 0 detected.</p>                                                      |
| 29-28<br>— | Reserved                                                                                                                                                                                                                                                                                                         |
| 27<br>SBC1 | <p>SBC1<br/>Memory 1 Single-Bit Correction Event</p> <p>Write 1 to clear this field. This write also clears the corresponding interrupt notification, if CR0[ESCIE1] is enabled.</p> <p>0b - No single-bit correction event on Memory 1 detected.<br/>1b - Single-bit correction event on Memory 1 detected.</p> |
| 26<br>NCE1 | <p>NCE1<br/>Memory 1 Non-Correctable Error Event</p> <p>Write 1 to clear this field. This write also clears the corresponding interrupt notification, if CR0[ENCIE1] is enabled.</p> <p>0b - No non-correctable error event on Memory 1 detected.<br/>1b - Non-correctable error event on Memory 1 detected.</p> |
| 25-24<br>— | Reserved                                                                                                                                                                                                                                                                                                         |
| 23-20<br>— | Reserved                                                                                                                                                                                                                                                                                                         |
| 19-16<br>— | Reserved                                                                                                                                                                                                                                                                                                         |
| 15-12<br>— | Reserved                                                                                                                                                                                                                                                                                                         |
| 11-8<br>—  | Reserved                                                                                                                                                                                                                                                                                                         |
| 7-4<br>—   | Reserved                                                                                                                                                                                                                                                                                                         |
| 3-0        | Reserved                                                                                                                                                                                                                                                                                                         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function |
|-------|----------|
| —     |          |

#### 9.5.4 ERM Memory 0 Error Address Register (EAR0)

##### Offset

| Register | Offset |
|----------|--------|
| EAR0     | 100h   |

##### Function

Each ERM Memory  $n$  Error Address Register is a 32-bit register for capturing the address of the last ECC event in Memory $n$ , where  $n$  denotes the memory channel. Any attempted write to EAR $n$  is ignored.

##### Diagram



##### Fields

| Field | Function                                                                                                                  |
|-------|---------------------------------------------------------------------------------------------------------------------------|
| 31-0  | EAR                                                                                                                       |
| EAR   | Memory $n$ Error Address — This field contains the faulting system address of the last recorded ECC event on Memory $n$ . |

#### 9.5.5 ERM Memory 0 Syndrome Register (SYN0)

##### Offset

| Register | Offset |
|----------|--------|
| SYN0     | 104h   |

## Function

The ERM Memory  $n$  Syndrome Register is a 32-bit register for capturing the calculated syndrome of the last ECC event on Memory $n$ , where  $n$  denotes the memory channel. Any attempted write to SYN $n$  is ignored. The syndrome value identifies the pertinent bit position on a correctable, single-bit data inversion or a non-correctable, single-bit address inversion. The syndrome value does not provide any additional diagnostic information on non-correctable, multi-bit inversions.

## Diagram

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

## Fields

| Field             | Function                                                                                                                           |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------|
| 31-24<br>SYNDROME | SYNDROME<br>Memory $n$ Syndrome — This field contains the ECC syndrome associated with the last recorded ECC event on Memory $n$ . |
| 23-0<br>—         | Reserved                                                                                                                           |

## 9.5.6 ERM Memory a Correctable Error Count Register (CORR\_ERR\_CNT0 - CORR\_ERR\_CNT1)

### Offset

| Register      | Offset |
|---------------|--------|
| CORR_ERR_CNT0 | 108h   |
| CORR_ERR_CNT1 | 118h   |

### Function

Each 32-bit ERM Memory  $n$  Correctable Error Count Register records the count value of the number of correctable ECC error events for Memory $n$ , where  $n$  denotes the memory channel.

#### NOTE

Non-correctable errors are considered a serious fault, so the ERM does not provide any mechanism to count non-correctable errors. Only correctable errors are counted.

**Diagram**

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

**Fields**

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 7-0<br>COUNT | <p>Memory n Correctable Error Count</p> <p>For each correctable error event, the ERM increments this field's error count value until the counter reaches its maximum value FFh. COUNT value will stop when it reaches maximum value FFh and will not wrap even if additional errors occur.</p> <p>Read this field to determine the correctable error count value so far.</p> <p>Write all zeros to this field to reset the counter. Writing a non-zero value has no effect.</p> |

# Chapter 10

## Signal Multiplexing

### 10.1 Introduction

Pins have several functions available via signal multiplexing to optimize functionality in small packages. This chapter illustrates which device's signals are multiplexed on which external pin.

See the attached MCXA1XX pinout spreadsheet to know how the pins available on this device are configured. The attached spreadsheet also provides the available device packages and pinout diagrams.

#### 10.1.1 Signal multiplexing constraints

- A given module signal must be assigned to a maximum of one package pin. Do not program the same function to more than one pin.
- To ensure the best signal timing for a given peripheral's interface, choose the pins in closest proximity to each other.

### 10.2 Pinout

See the attached MCXA1xx pinout spreadsheet for the pinouts and ballmaps for each package offered on this device.

### 10.3 Pinmux view

Table 61. pinmux

| Pin Name | MCXA14x15x<br>64LQFP | MCXA14x15x<br>48QFN | MCXA14x15x<br>32QFN | Pinmux Assignment                                                                                                                                         | Pad Settings                                                               | Alternate Functions                                |
|----------|----------------------|---------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|----------------------------------------------------|
| P1_8     | 2                    | 1                   | 1                   | <b>ALT0</b> - P1_8<br><b>ALT2</b> - LPUART1_RXD<br><b>ALT3</b> - LPI2C0_SDA<br><b>ALT4</b> - CT_INP8<br><b>ALT5</b> - CT0_MAT2<br><b>ALT10</b> - I3C0_SDA | <b>IO Supply</b> - VDD<br><b>Pad type</b> - HD+I3C<br><b>Default</b> - DIS | <b>ISP</b> - I2C_SDA<br><b>VDD SYS</b> - WUU0_IN10 |
| P1_9     | 3                    | 2                   | 2                   | <b>ALT0</b> - P1_9<br><b>ALT2</b> - LPUART1_TXD<br><b>ALT3</b> - LPI2C0_SCL<br><b>ALT4</b> - CT_INP9<br><b>ALT5</b> - CT0_MAT3<br><b>ALT10</b> - I3C0_SCL | <b>IO Supply</b> - VDD<br><b>Pad type</b> - HD<br><b>Default</b> - DIS     | <b>ISP</b> - I2C_SCL                               |
| P1_10    | 4                    | 3                   | --                  | <b>ALT0</b> - P1_10<br><b>ALT2</b> - LPUART1_RTS_B<br><b>ALT3</b> - LPI2C0_SDAS<br><b>ALT4</b> - CT2_MAT0                                                 | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS   | <b>ANALOG</b> - ADC0_A8                            |
| P1_11    | 5                    | 4                   | --                  | <b>ALT0</b> - P1_11                                                                                                                                       | <b>IO Supply</b> - VDD                                                     | <b>ANALOG</b> - ADC0_A9                            |

Table continues on the next page...

Table 61. pinmux (continued)

| Pin Name | MCXA14x15x<br>64LQFP | MCXA14x15x<br>48QFN | MCXA14x15x<br>32QFN | Pinmux Assignment                                                                                                                        | Pad Settings                                                               | Alternate Functions                                    |
|----------|----------------------|---------------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--------------------------------------------------------|
|          |                      |                     |                     | <b>ALT1</b> - TRIG_OUT2<br><b>ALT2</b> - LPUART1_CTS_B<br><b>ALT3</b> - LPI2C0_SCLS<br><b>ALT4</b> - CT2_MAT1<br><b>ALT10</b> - I3C0_PUR | <b>Pad type</b> - SLOW<br><b>Default</b> - DIS                             | <b>VDD SYS</b> - WUU0_IN11                             |
| P1_12    | 6                    | --                  | --                  | <b>ALT0</b> - P1_12<br><b>ALT3</b> - LPUART2_RXD<br><b>ALT4</b> - CT2_MAT2                                                               | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS   | <b>ANALOG</b> - ADC0_A10<br><b>VDD SYS</b> - WUU0_IN12 |
| P1_13    | 7                    | --                  | --                  | <b>ALT0</b> - P1_13<br><b>ALT1</b> - TRIG_IN3<br><b>ALT3</b> - LPUART2_TXD<br><b>ALT4</b> - CT2_MAT3                                     | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS   | <b>ANALOG</b> - ADC0_A11                               |
| P1_29    | 8                    | 5                   | 3                   | <b>ALT0</b> - P1_29<br><b>ALT1</b> - RESET_B<br><b>ALT2</b> - SPC_LPREQ                                                                  | <b>IO Supply</b> - VDD<br><b>Pad type</b> - RST<br><b>Default</b> - ALT1   | <b>VDD SYS</b> - RESET_B                               |
| P1_30    | 9                    | 6                   | 4                   | <b>ALT0</b> - P1_30<br><b>ALT1</b> - TRIG_OUT3<br><b>ALT3</b> - LPI2C0_SDA<br><b>ALT4</b> - CT_INP16<br><b>ALT10</b> - I3C0_SDA          | <b>IO Supply</b> - VDD<br><b>Pad type</b> - HD+I3C<br><b>Default</b> - DIS | <b>ANALOG</b> - XTAL48M                                |
| P1_31    | 10                   | 7                   | 5                   | <b>ALT0</b> - P1_31<br><b>ALT1</b> - TRIG_IN4<br><b>ALT3</b> - LPI2C0_SCL<br><b>ALT4</b> - CT_INP17<br><b>ALT10</b> - I3C0_SCL           | <b>IO Supply</b> - VDD<br><b>Pad type</b> - HD<br><b>Default</b> - DIS     | <b>ANALOG</b> - EXTAL48M                               |
| VSS      | 11                   | 0                   | 0                   |                                                                                                                                          | <b>IO Supply</b> - VDD                                                     |                                                        |
| VDD_ANA  | 12                   | 8                   | 6                   |                                                                                                                                          | <b>IO Supply</b> - VDD                                                     |                                                        |
| VDD      | 13                   | 9                   | 7                   |                                                                                                                                          | <b>IO Supply</b> - VDD                                                     |                                                        |
| P2_0     | 14                   | 10                  | --                  | <b>ALT0</b> - P2_0<br><b>ALT1</b> - TRIG_IN6<br><b>ALT2</b> - LPUART0_RXD<br><b>ALT4</b> - CT_INP16<br><b>ALT5</b> - CT2_MAT0            | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS   | <b>ANALOG</b> - ADC0_A0<br><b>VDD SYS</b> - WUU0_IN18  |
| P2_1     | 15                   | 11                  | --                  | <b>ALT0</b> - P2_1                                                                                                                       | <b>IO Supply</b> - VDD                                                     | <b>ANALOG</b> - ADC0_A1                                |

Table continues on the next page...

Table 61. pinmux (continued)

| Pin Name | MCXA14x15x<br>64LQFP | MCXA14x15x<br>48QFN | MCXA14x15x<br>32QFN | Pinmux Assignment                                                                                                                                            | Pad Settings                                                             | Alternate Functions                                               |
|----------|----------------------|---------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|-------------------------------------------------------------------|
|          |                      |                     |                     | <b>ALT1</b> - TRIG_IN7<br><b>ALT2</b> - LPUART0_TXD<br><b>ALT4</b> - CT_INP17<br><b>ALT5</b> - CT2_MAT1                                                      | <b>Pad type</b> - SLOW<br><b>Default</b> - DIS                           |                                                                   |
| P2_2     | 16                   | 12                  | 8                   | <b>ALT0</b> - P2_2<br><b>ALT1</b> - TRIG_IN6<br><b>ALT2</b> - LPUART0_RTS_B<br><b>ALT3</b> - LPUART2_TXD<br><b>ALT4</b> - CT_INP12<br><b>ALT5</b> - CT2_MAT2 | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS | <b>ANALOG</b> -<br>ADC0_A4/CMP0_IN0                               |
| P2_3     | 17                   | 13                  | 9                   | <b>ALT0</b> - P2_3<br><b>ALT1</b> - TRIG_IN7<br><b>ALT2</b> - LPUART0_CTS_B<br><b>ALT3</b> - LPUART2_RXD<br><b>ALT4</b> - CT_INP13<br><b>ALT5</b> - CT2_MAT3 | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS | <b>ANALOG</b> -<br>ADC0_A2/CMP1_IN0<br><b>VDD SYS</b> - WU00_IN19 |
| P2_4     | 18                   | --                  | --                  | <b>ALT0</b> - P2_4<br><b>ALT4</b> - CT_INP14<br><b>ALT5</b> - CT1_MAT0                                                                                       | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS |                                                                   |
| P2_5     | 19                   | --                  | --                  | <b>ALT0</b> - P2_5<br><b>ALT4</b> - CT_INP15<br><b>ALT5</b> - CT1_MAT1                                                                                       | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS |                                                                   |
| P2_6     | 20                   | 14                  | --                  | <b>ALT0</b> - P2_6<br><b>ALT1</b> - TRIG_OUT4<br><b>ALT2</b> - LPSP1_PCS1<br><b>ALT4</b> - CT_INP18<br><b>ALT5</b> - CT1_MAT2                                | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS | <b>ANALOG</b> - ADC0_A3                                           |
| P2_7     | 21                   | 15                  | 10                  | <b>ALT0</b> - P2_7<br><b>ALT1</b> - TRIG_IN5<br><b>ALT4</b> - CT_INP19<br><b>ALT5</b> - CT1_MAT3                                                             | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS |                                                                   |
| P2_7     | 21                   | 15                  | 10                  |                                                                                                                                                              | <b>IO Supply</b> - VDD<br><b>Pad type</b> - ANA                          | <b>ANALOG</b> - VREFI/ADC0_A7                                     |
| P2_12    | 22                   | 16                  | 11                  | <b>ALT0</b> - P2_12<br><b>ALT1</b> - USB0_VBUS_DET                                                                                                           | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW                         | <b>ISP</b> - USB0_VBUS_DET<br><b>ANALOG</b> - ADC0_A5             |

Table continues on the next page...

Table 61. pinmux (continued)

| Pin Name | MCXA14x15x<br>64LQFP | MCXA14x15x<br>48QFN | MCXA14x15x<br>32QFN | Pinmux Assignment                                                                                                                | Pad Settings                                                              | Alternate Functions                                                              |
|----------|----------------------|---------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|----------------------------------------------------------------------------------|
|          |                      |                     |                     | <b>ALT2</b> - LPSP11_SCK<br><b>ALT3</b> - LPUART1_RXD<br><b>ALT5</b> - CT0_MAT0                                                  | <b>Default</b> - DIS                                                      | <b>VDD SYS</b> - WUU0_IN20                                                       |
| P2_13    | 23                   | 17                  | --                  | <b>ALT0</b> - P2_13<br><b>ALT1</b> - TRIG_IN8<br><b>ALT2</b> - LPSP11_SDO<br><b>ALT3</b> - LPUART1_TXD<br><b>ALT5</b> - CT0_MAT1 | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS  |                                                                                  |
| P2_16    | 24                   | 18                  | --                  | <b>ALT0</b> - P2_16<br><b>ALT2</b> - LPSP11_SDI<br><b>ALT3</b> - LPUART1_RTS_B<br><b>ALT5</b> - CT0_MAT2                         | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS  | <b>ANALOG</b> - ADC0_A6                                                          |
| VDD_USB  | 25                   | 19                  | 12                  |                                                                                                                                  | <b>IO Supply</b> - VDD_USB                                                |                                                                                  |
| USB0_DM  | 26                   | 20                  | 13                  |                                                                                                                                  | <b>IO Supply</b> - VDD_USB<br><b>Pad type</b> - ANA                       | <b>ANALOG</b> - USB0_DM<br><b>VDD SYS</b> - WUU0_IN28                            |
| USB0_DP  | 27                   | 21                  | 14                  |                                                                                                                                  | <b>IO Supply</b> - VDD_USB<br><b>Pad type</b> - ANA                       | <b>ANALOG</b> - USB0_DP<br><b>VDD SYS</b> - WUU0_IN29                            |
| VSS      | 28                   | 0                   | 0                   |                                                                                                                                  | <b>IO Supply</b> - VDD                                                    |                                                                                  |
| VDD      | 29                   | 22                  | --                  |                                                                                                                                  | <b>IO Supply</b> - VDD                                                    |                                                                                  |
| P3_31    | 30                   | 23                  | --                  | <b>ALT0</b> - P3_31<br><b>ALT1</b> - TRIG_IN10<br><b>ALT4</b> - CT0_MAT3                                                         | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS  | <b>ANALOG</b> - ADC0_A12<br><b>VDD SYS</b> - LPTMR0_ALT2                         |
| P3_30    | 31                   | 24                  | --                  | <b>ALT0</b> - P3_30<br><b>ALT1</b> - TRIG_OUT6<br><b>ALT4</b> - CT0_MAT2                                                         | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS  | <b>ANALOG</b> - ADC0_A13                                                         |
| P3_29    | 32                   | 25                  | 15                  | <b>ALT0</b> - P3_29<br><b>ALT1</b> - ISPMODE_N<br><b>ALT4</b> - CT_INP3                                                          | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - ALT1 | <b>ISP</b> - ISPMODE_N<br><b>ANALOG</b> - ADC0_A14<br><b>VDD SYS</b> - WUU0_IN27 |
| P3_28    | 33                   | 26                  | 16                  | <b>ALT0</b> - P3_28<br><b>ALT1</b> - TRIG_IN11<br><b>ALT2</b> - LPI2C0_SDA<br><b>ALT4</b> - CT_INP12                             | <b>IO Supply</b> - VDD<br><b>Pad type</b> - 5VTOL<br><b>Default</b> - DIS | <b>VDD SYS</b> - WUU0_IN26                                                       |
| P3_27    | 34                   | 27                  | 17                  | <b>ALT0</b> - P3_27<br><b>ALT1</b> - TRIG_OUT7                                                                                   | <b>IO Supply</b> - VDD<br><b>Pad type</b> - 5VTOL                         |                                                                                  |

Table continues on the next page...

Table 61. pinmux (continued)

| Pin Name | MCXA14x15x<br>64LQFP | MCXA14x15x<br>48QFN | MCXA14x15x<br>32QFN | Pinmux Assignment                                                                                                                                            | Pad Settings                                                             | Alternate Functions        |
|----------|----------------------|---------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|----------------------------|
|          |                      |                     |                     | <b>ALT2</b> - LPI2C0_SCL<br><b>ALT4</b> - CT_INP13                                                                                                           | <b>Default</b> - DIS                                                     |                            |
| P3_15    | 35                   | --                  | --                  | <b>ALT0</b> - P3_15<br><b>ALT2</b> - LPUART2_TXD<br><b>ALT4</b> - CT_INP7                                                                                    | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS |                            |
| P3_14    | 36                   | 28                  | --                  | <b>ALT0</b> - P3_14<br><b>ALT2</b> - LPUART2_RXD<br><b>ALT4</b> - CT_INP6<br><b>ALT5</b> - PWM0_X2                                                           | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS | <b>VDD SYS</b> - WUU0_IN25 |
| P3_13    | 37                   | 29                  | --                  | <b>ALT0</b> - P3_13<br><b>ALT2</b> - LPUART2_CTS_B<br><b>ALT4</b> - CT1_MAT3<br><b>ALT5</b> - PWM0_X1                                                        | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS |                            |
| P3_12    | 38                   | 30                  | --                  | <b>ALT0</b> - P3_12<br><b>ALT2</b> - LPUART2_RTS_B<br><b>ALT4</b> - CT1_MAT2<br><b>ALT5</b> - PWM0_X0                                                        | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS |                            |
| P3_11    | 39                   | 31                  | 18                  | <b>ALT0</b> - P3_11<br><b>ALT1</b> - TRIG_IN6<br><b>ALT2</b> - LPSP11_PCS0<br><b>ALT3</b> - LPUART1_CTS_B<br><b>ALT4</b> - CT1_MAT1<br><b>ALT5</b> - PWM0_B2 | <b>IO Supply</b> - VDD<br><b>Pad type</b> - MED<br><b>Default</b> - DIS  | <b>VDD SYS</b> - WUU0_IN24 |
| P3_10    | 40                   | 32                  | 19                  | <b>ALT0</b> - P3_10<br><b>ALT1</b> - TRIG_IN5<br><b>ALT2</b> - LPSP11_SCK<br><b>ALT3</b> - LPUART1_RTS_B<br><b>ALT4</b> - CT1_MAT0<br><b>ALT5</b> - PWM0_A2  | <b>IO Supply</b> - VDD<br><b>Pad type</b> - MED<br><b>Default</b> - DIS  |                            |
| P3_9     | 41                   | 33                  | 20                  | <b>ALT0</b> - P3_9<br><b>ALT1</b> - TRIG_IN4<br><b>ALT2</b> - LPSP11_SD1<br><b>ALT3</b> - LPUART1_TXD<br><b>ALT4</b> - CT_INP5<br><b>ALT5</b> - PWM0_B1      | <b>IO Supply</b> - VDD<br><b>Pad type</b> - MED<br><b>Default</b> - DIS  |                            |

Table continues on the next page...

Table 61. pinmux (continued)

| Pin Name | MCXA14x15x<br>64LQFP | MCXA14x15x<br>48QFN | MCXA14x15x<br>32QFN | Pinmux Assignment                                                                                                                                                                | Pad Settings                                                             | Alternate Functions        |
|----------|----------------------|---------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|----------------------------|
| P3_8     | 42                   | 34                  | 21                  | <b>ALT0</b> - P3_8<br><b>ALT1</b> - TRIG_IN3<br><b>ALT2</b> - LPSP11_SDO<br><b>ALT3</b> - LPUART1_RXD<br><b>ALT4</b> - CT_INP4<br><b>ALT5</b> - PWM0_A1<br><b>ALT12</b> - CLKOUT | <b>IO Supply</b> - VDD<br><b>Pad type</b> - MED<br><b>Default</b> - DIS  | <b>VDD SYS</b> - WUU0_IN23 |
| P3_7     | 43                   | --                  | --                  | <b>ALT0</b> - P3_7<br><b>ALT1</b> - TRIG_IN2<br><b>ALT2</b> - LPSP11_PCS2<br><b>ALT5</b> - PWM0_B0                                                                               | <b>IO Supply</b> - VDD<br><b>Pad type</b> - MED<br><b>Default</b> - DIS  |                            |
| P3_6     | 44                   | --                  | --                  | <b>ALT0</b> - P3_6<br><b>ALT1</b> - CLKOUT<br><b>ALT2</b> - LPSP11_PCS3<br><b>ALT5</b> - PWM0_A0<br><b>ALT12</b><br>- FREQME_CLK_OUT1                                            | <b>IO Supply</b> - VDD<br><b>Pad type</b> - MED<br><b>Default</b> - DIS  |                            |
| P3_1     | 45                   | 35                  | 22                  | <b>ALT0</b> - P3_1<br><b>ALT1</b> - TRIG_IN1<br><b>ALT4</b> - CT_INP17<br><b>ALT5</b> - PWM0_B0<br><b>ALT12</b><br>- FREQME_CLK_OUT0                                             | <b>IO Supply</b> - VDD<br><b>Pad type</b> - HD<br><b>Default</b> - DIS   |                            |
| P3_0     | 46                   | 36                  | 23                  | <b>ALT0</b> - P3_0<br><b>ALT1</b> - TRIG_IN0<br><b>ALT4</b> - CT_INP16<br><b>ALT5</b> - PWM0_A0                                                                                  | <b>IO Supply</b> - VDD<br><b>Pad type</b> - HD<br><b>Default</b> - DIS   | <b>VDD SYS</b> - WUU0_IN22 |
| VSS      | 47                   | 0                   | 0                   |                                                                                                                                                                                  | <b>IO Supply</b> - VDD                                                   |                            |
| VDD      | 48                   | 37                  | 24                  |                                                                                                                                                                                  | <b>IO Supply</b> - VDD                                                   |                            |
| P0_0     | 49                   | 38                  | 25                  | <b>ALT0</b> - P0_0<br><b>ALT1</b> - TMS/SWDIO<br><b>ALT2</b> - LPUART0_RTS_B<br><b>ALT3</b> - LPSP10_PCS0<br><b>ALT4</b> - CT_INP0                                               | <b>IO Supply</b> - VDD<br><b>Pad type</b> - MED<br><b>Default</b> - ALT1 |                            |
| P0_1     | 50                   | 39                  | 26                  | <b>ALT0</b> - P0_1                                                                                                                                                               | <b>IO Supply</b> - VDD                                                   |                            |

Table continues on the next page...

Table 61. pinmux (continued)

| Pin Name | MCXA14x15x<br>64LQFP | MCXA14x15x<br>48QFN | MCXA14x15x<br>32QFN | Pinmux Assignment                                                                                                                                                                     | Pad Settings                                                               | Alternate Functions                               |
|----------|----------------------|---------------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|---------------------------------------------------|
|          |                      |                     |                     | <b>ALT1</b> - TCLK/SWCLK<br><b>ALT2</b> - LPUART0_CTS_B<br><b>ALT3</b> - LPSP10_SDI<br><b>ALT4</b> - CT_INP1                                                                          | <b>Pad type</b> - MED<br><b>Default</b> - ALT1                             |                                                   |
| P0_2     | 51                   | 40                  | 27                  | <b>ALT0</b> - P0_2<br><b>ALT1</b> - TDO/SWO<br><b>ALT2</b> - LPUART0_RXD<br><b>ALT3</b> - LPSP10_SCK<br><b>ALT4</b> - CT0_MAT0<br><b>ALT5</b> - UTICK_CAP0<br><b>ALT10</b> - I3C0_PUR | <b>IO Supply</b> - VDD<br><b>Pad type</b> - MED<br><b>Default</b> - ALT1   | <b>ISP</b> - UART_RXD                             |
| P0_3     | 52                   | 41                  | 28                  | <b>ALT0</b> - P0_3<br><b>ALT1</b> - TDI<br><b>ALT2</b> - LPUART0_TXD<br><b>ALT3</b> - LPSP10_SDO<br><b>ALT4</b> - CT0_MAT1<br><b>ALT5</b> - UTICK_CAP1<br><b>ALT8</b> - CMP0_OUT      | <b>IO Supply</b> - VDD<br><b>Pad type</b> - MED<br><b>Default</b> - ALT1   | <b>ISP</b> - UART_TXD<br><b>ANALOG</b> - CMP1_IN1 |
| P0_6     | 53                   | 42                  | --                  | <b>ALT0</b> - P0_6<br><b>ALT2</b> - LPI2C0_HREQ<br><b>ALT3</b> - LPSP10_PCS1<br><b>ALT4</b> - CT_INP2<br><b>ALT8</b> - CMP1_OUT<br><b>ALT12</b> - CLKOUT                              | <b>IO Supply</b> - VDD<br><b>Pad type</b> - SLOW<br><b>Default</b> - DIS   | <b>ANALOG</b> - ADC0_A15                          |
| P0_16    | 54                   | 43                  | --                  | <b>ALT0</b> - P0_16<br><b>ALT2</b> - LPI2C0_SDA<br><b>ALT3</b> - LPSP10_PCS2<br><b>ALT4</b> - CT0_MAT0<br><b>ALT5</b> - UTICK_CAP2<br><b>ALT10</b> - I3C0_SDA                         | <b>IO Supply</b> - VDD<br><b>Pad type</b> - HD+I3C<br><b>Default</b> - DIS | <b>VDD SYS</b> - WUU0_IN2                         |
| P0_17    | 55                   | 44                  | --                  | <b>ALT0</b> - P0_17<br><b>ALT2</b> - LPI2C0_SCL<br><b>ALT3</b> - LPSP10_PCS3<br><b>ALT4</b> - CT0_MAT1<br><b>ALT5</b> - UTICK_CAP3<br><b>ALT10</b> - I3C0_SCL                         | <b>IO Supply</b> - VDD<br><b>Pad type</b> - HD<br><b>Default</b> - DIS     |                                                   |

Table continues on the next page...

Table 61. pinmux (continued)

| Pin Name | MCXA14x15x<br>64LQFP | MCXA14x15x<br>48QFN | MCXA14x15x<br>32QFN | Pinmux Assignment                                                                                                                                          | Pad Settings                                                                     | Alternate Functions                                                                                |
|----------|----------------------|---------------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|
| P1_0     | 56                   | 45                  | 29                  | <b>ALT0</b> - P1_0<br><b>ALT1</b> - TRIG_IN0<br><b>ALT2</b> - LPSP10_SDO<br><b>ALT3</b> - LPI2C0_SDA<br><b>ALT4</b> - CT_INP4<br><b>ALT5</b> - CT0_MAT2    | <b>IO Supply</b> - VDD<br><b>Pad type</b> - MED+I2C_FILT<br><b>Default</b> - DIS | <b>ISP</b> - SPI_SDO<br><b>ANALOG</b> - ADC0_A16/CMP0_IN3<br><b>VDD SYS</b> - WUU0_IN6/LPTMR0_ALT3 |
| P1_1     | 57                   | 46                  | 30                  | <b>ALT0</b> - P1_1<br><b>ALT1</b> - TRIG_IN1<br><b>ALT2</b> - LPSP10_SCK<br><b>ALT3</b> - LPI2C0_SCL<br><b>ALT4</b> - CT_INP5<br><b>ALT5</b> - CT0_MAT3    | <b>IO Supply</b> - VDD<br><b>Pad type</b> - MED+I2C_FILT<br><b>Default</b> - DIS | <b>ISP</b> - SPI_SCK<br><b>ANALOG</b> - ADC0_A17/CMP1_IN3                                          |
| P1_2     | 58                   | 47                  | 31                  | <b>ALT0</b> - P1_2<br><b>ALT1</b> - TRIG_OUT0<br><b>ALT2</b> - LPSP10_SD1<br><b>ALT3</b> - LPI2C0_SDAS<br><b>ALT4</b> - CT1_MAT0<br><b>ALT5</b> - CT_INP0  | <b>IO Supply</b> - VDD<br><b>Pad type</b> - MED<br><b>Default</b> - DIS          | <b>ISP</b> - SPI_SDI<br><b>ANALOG</b> - ADC0_A18                                                   |
| P1_3     | 59                   | 48                  | 32                  | <b>ALT0</b> - P1_3<br><b>ALT1</b> - TRIG_OUT1<br><b>ALT2</b> - LPSP10_PCS0<br><b>ALT3</b> - LPI2C0_SCLS<br><b>ALT4</b> - CT1_MAT1<br><b>ALT5</b> - CT_INP1 | <b>IO Supply</b> - VDD<br><b>Pad type</b> - MED<br><b>Default</b> - DIS          | <b>ISP</b> - SPI_PCS<br><b>ANALOG</b> - ADC0_A19/CMP0_IN1<br><b>VDD SYS</b> - WUU0_IN7             |
| VDD      | 60                   | --                  | --                  |                                                                                                                                                            | <b>IO Supply</b> - VDD                                                           |                                                                                                    |
| VSS      | 61                   | --                  | --                  |                                                                                                                                                            | <b>IO Supply</b> - VDD                                                           |                                                                                                    |
| P1_4     | 62                   | --                  | --                  | <b>ALT0</b> - P1_4<br><b>ALT1</b> - FREQME_CLK_IN0<br><b>ALT2</b> - LPSP10_PCS3<br><b>ALT3</b> - LPUART2_RXD<br><b>ALT4</b> - CT1_MAT2                     | <b>IO Supply</b> - VDD<br><b>Pad type</b> - MED<br><b>Default</b> - DIS          | <b>ANALOG</b> - ADC0_A20/CMP0_IN2<br><b>VDD SYS</b> - WUU0_IN8                                     |
| P1_5     | 63                   | --                  | --                  | <b>ALT0</b> - P1_5<br><b>ALT1</b> - FREQME_CLK_IN1<br><b>ALT2</b> - LPSP10_PCS2<br><b>ALT3</b> - LPUART2_TXD                                               | <b>IO Supply</b> - VDD<br><b>Pad type</b> - MED<br><b>Default</b> - DIS          | <b>ANALOG</b> - ADC0_A21/CMP1_IN2                                                                  |

Table continues on the next page...

Table 61. pinmux (continued)

| Pin Name | MCXA14x15x<br>64LQFP | MCXA14x15x<br>48QFN | MCXA14x15x<br>32QFN | Pinmux Assignment                                                                                                                 | Pad Settings                                                            | Alternate Functions                                   |
|----------|----------------------|---------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|-------------------------------------------------------|
|          |                      |                     |                     | <b>ALT4</b> - CT1_MAT3                                                                                                            |                                                                         |                                                       |
| P1_6     | 64                   | --                  | --                  | <b>ALT0</b> - P1_6<br><b>ALT1</b> - TRIG_IN2<br><b>ALT2</b> - LPSCI0_PCS1<br><b>ALT3</b> - LPUART2_RTS_B<br><b>ALT4</b> - CT_INP6 | <b>IO Supply</b> - VDD<br><b>Pad type</b> - MED<br><b>Default</b> - DIS | <b>ANALOG</b> - ADC0_A22                              |
| P1_7     | 1                    | --                  | --                  | <b>ALT0</b> - P1_7<br><b>ALT1</b> - TRIG_OUT2<br><b>ALT3</b> - LPUART2_CTS_B<br><b>ALT4</b> - CT_INP7                             | <b>IO Supply</b> - VDD<br><b>Pad type</b> - MED<br><b>Default</b> - DIS | <b>ANALOG</b> - ADC0_A23<br><b>VDD SYS</b> - WUU0_IN9 |

Note

# Chapter 11

## Port Control (PORT)

### 11.1 Chip-specific PORT information

Table 62. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | PORT           | <a href="#">PORT</a>                |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 11.1.1 Module instances

This device has four instances of the port module, PORT0, PORT1, PORT2, and PORT3.

### 11.2 Overview

PORT provides support for pad control functions. You can configure most functions independently for each pin, in the 32-bit port, and affect the pin regardless of its pin multiplexing state.

There exists a single instance of the PORT module for each port, and not all pins within each port are implemented on a specific chip.

#### 11.2.1 Block diagram



Figure 14. Block diagram

#### 11.2.2 Features

- Individual pull control fields with pullup, pulldown, and pull-disable support

- Individual drive strength fields supporting high and low drive strengths
- Individual slew rate fields supporting fast and slow slew rates
- Individual PCR $n$ [PFE] fields that enable and disable individual input passive filters on selected pins
- Individual PCR $n$ [ODE] fields that enable and disable individual open drain outputs
- Digital input inversion to optionally invert the digital input
- Digital PCR $n$ [IBE] fields to configure between analog or disabled functions and digital functions
- Individual PCR $n$ [MUX] fields supporting GPIO and up to 12 chip-specific digital functions

## 11.3 Functional description

### 11.3.1 Pin control

Each port pin has a corresponding Pin Control Register (PCR) associated with it that helps you configure the following functions for each pin within the 32-bit port:

- Pullup or pulldown enable
- Drive strength configuration
- Slew rate configuration
- Open drain enable
- Passive input filter enable on selected pins
- Digital input inversion
- Software configuration lock
- Pin multiplexing mode

These functions apply across all digital pin multiplexing modes, and individual peripherals do not override the configuration in PCR $n$  unless otherwise noted. For example, if an I<sup>2</sup>C function is enabled on a pin, it does not override the pullup or open drain configuration for that pin.

PCR $n$ [LK] allows the configuration for each pin to be locked until the next system reset. When locked, writes to the lower half of that PCR $n$  are ignored, although a bus error is not generated on an attempted write to a locked register.

The configuration of each PCR $n$  is retained when the PORT module is disabled.

When you configure a pin in a digital pin multiplexing mode, the input buffer for that pin is enabled, allowing the pin state to be read via the corresponding GPIO.PDIR or allowing a pin interrupt or DMA request to be generated. If a pin is always floating when its input buffer is enabled, it can cause an increase in power consumption. This situation must be avoided. A pin can be floating because of an input pin that is not connected or an output pin that is tristated (output buffer is disabled).

Enabling the internal pull resistor (or implementing an external pull resistor) ensures that a pin does not float when its input buffer is enabled. The internal pull resistor is automatically disabled whenever the output buffer is enabled, allowing PCR $n$ [PE] to remain 1. Configuring Pin Multiplexing mode to disabled or analog (PCR $n$ [MUX] = 0) disables the pin's input buffer and results in lowest power consumption.

### 11.3.2 Global pin control

[Global Pin Control Low \(GPCLR\)](#) and [Global Pin Control High \(GPCHR\)](#) allow a single register write to update the lower 16 bits of PCR $n$  for up to 16 pins, all with the same value. You cannot write to locked registers by using [Global Pin Control Low \(GPCLR\)](#) and [Global Pin Control High \(GPCHR\)](#).

[Global Pin Control Low \(GPCLR\)](#) and [Global Pin Control High \(GPCHR\)](#) enable you to quickly configure multiple pins within the same port and with the same peripheral function. These are write-only registers that always read as 0.

### 11.3.3 Clocking

This module has no clocking considerations.

### 11.3.4 Calibration

The combination of [Calibration 0 \(CALIB0\)](#) and [Calibration 1 \(CALIB1\)](#) controls the drive strength of a pin for the port and PCR $n$ [DSE] for the pin.

[Calibration 0 \(CALIB0\)](#) and [Calibration 1 \(CALIB1\)](#) represent two driver configurations. If PCR $n$ [DSE] = 0, the configuration in [Calibration 0 \(CALIB0\)](#) is used. Likewise, if PCR $n$ [DSE] = 1, the configuration in [Calibration 1 \(CALIB1\)](#) is used.

The pulldown and pullup drivers have eight segments. The value of NCAL[5:3] represents the number of pulldown segments that are enabled when driving low, and the value of PCAL[5:3] represents the number of pullup segments that turn on when driving high. Writing 000b to these fields causes one segment to turn on, while writing 111b causes all eight segments to turn on. Upon reset, [Calibration 0 \(CALIB0\)](#) becomes 1 to create approximately 50  $\Omega$  driver at 3.3 V and 25 °C (3 is a typical value) and [Calibration 1 \(CALIB1\)](#) becomes 1 to create approximately 50  $\Omega$  driver at 1.8 V and 25 °C (7 is the typical value).

The three LSBs of [CALIB0\[NCAL\]](#), [CALIB1\[NCAL\]](#), [CALIB0\[PCAL\]](#), and [CALIB1\[PCAL\]](#) do not affect the driver's strength. Instead, they are included to improve precision when calibrating to a different impedance value. This can be done by using the following formula:

Calibration = (G × (CAL0 + 4) – 1024) >> 8, where G is a binary code representing the desired conductance and CAL0 is one of the 6-bit fields in [Calibration 0 \(CALIB0\)](#) and [Calibration 1 \(CALIB1\)](#). The value of G scales linearly with the intended conductance; G = 0 corresponds to 0 S (an open circuit), and G = 256 corresponds to 0.02 S (50  $\Omega$ ). For example, the following operation configures the driver to be approximately 0.03 S (33  $\Omega$ ) at 3.3 V when PCR $n$ [DSE] = 1:

The value of [CALIB1\[NCAL\]](#) = (384 × (the value of [CALIB0\[NCAL\]](#) + 4) – 1024) >> 8;

The value of [CALIB1\[PCAL\]](#) = (384 × (the value of [CALIB0\[PCAL\]](#) + 4) – 1024) >> 8;

Do not overflow or underflow NCAL[5:3] or PCAL[5:3]; otherwise, this operation may have an unintended result. You can configure the drive strength for 50  $\Omega$  at 2.5 V and 25 °C by averaging the initial NCAL codes in [Calibration 0 \(CALIB0\)](#) and [Calibration 1 \(CALIB1\)](#), and averaging the initial PCAL codes in [Calibration 0 \(CALIB0\)](#) and [Calibration 1 \(CALIB1\)](#). However, the 2.5 V configuration is not as accurate or precise as the original 1.8 V and 3.3 V configuration because the drive strength is not perfectly linear with supply voltage.

#### NOTE

This calibration feature may not apply to all PORT pins. See the chip-specific PORT information for pins that support calibration.

## 11.4 Initialization

To initialize PORT, perform the following procedure:

1. Initialize the pin functions:
  - Initialize single pin functions by writing appropriate values to PCR $n$ .
  - Initialize multiple pins (up to 16) with the same configuration by writing appropriate values to [Global Pin Control Low \(GPCLR\)](#) or [Global Pin Control High \(GPCHR\)](#).
2. Lock the configuration for a given pin, by writing 1 to PCR $n$ [LK], so that it cannot be changed until the next reset.

## 11.5 Application information

### 11.6 Memory map and register definition

Any read or write access to the PORT memory space, outside the valid memory map, results in a bus error. All register accesses complete with zero wait states.

## 11.6.1 PORT register descriptions

### 11.6.1.1 PORT memory map

PORT0 base address: 400B\_C000h

PORT1 base address: 400B\_D000h

PORT2 base address: 400B\_E000h

PORT3 base address: 400B\_F000h

| Offset     | Register                        | Width<br>(In bits) | Access | Reset value                 |
|------------|---------------------------------|--------------------|--------|-----------------------------|
| 0h         | Version ID (VERID)              | 32                 | R      | 0200_0000h                  |
| 10h        | Global Pin Control Low (GPCLR)  | 32                 | W      | 0000_0000h                  |
| 14h        | Global Pin Control High (GPCHR) | 32                 | W      | 0000_0000h                  |
| 20h        | Configuration (CONFIG)          | 32                 | RW     | 0000_0000h                  |
| 60h        | Calibration 0 (CALIB0)          | 32                 | RW     | <a href="#">See section</a> |
| 64h        | Calibration 1 (CALIB1)          | 32                 | RW     | <a href="#">See section</a> |
| 80h        | Pin Control 0 (PCR0)            | 32                 | RW     | <a href="#">See section</a> |
| 84h        | Pin Control 1 (PCR1)            | 32                 | RW     | <a href="#">See section</a> |
| 88h        | Pin Control 2 (PCR2)            | 32                 | RW     | <a href="#">See section</a> |
| 8Ch        | Pin Control 3 (PCR3)            | 32                 | RW     | <a href="#">See section</a> |
| 90h - 98h  | Pin Control a (PCR4 - PCR6)     | 32                 | RW     | <a href="#">See section</a> |
| 9Ch        | Pin Control 7 (PCR7)            | 32                 | RW     | 0000_0000h                  |
| A0h        | Pin Control 8 (PCR8)            | 32                 | RW     | 0000_0000h                  |
| A4h        | Pin Control 9 (PCR9)            | 32                 | RW     | 0000_0000h                  |
| A8h - B4h  | Pin Control a (PCR10 - PCR13)   | 32                 | RW     | <a href="#">See section</a> |
| B8h - BCCh | Pin Control a (PCR14 - PCR15)   | 32                 | RW     | 0000_0000h                  |
| C0h        | Pin Control 16 (PCR16)          | 32                 | RW     | 0000_0000h                  |
| C4h        | Pin Control 17 (PCR17)          | 32                 | RW     | 0000_0000h                  |
| D0h - D4h  | Pin Control a (PCR20 - PCR21)   | 32                 | RW     | 0000_0000h                  |
| ECh - F0h  | Pin Control a (PCR27 - PCR28)   | 32                 | RW     | 0000_0000h                  |
| F4h        | Pin Control 29 (PCR29)          | 32                 | RW     | <a href="#">See section</a> |
| F8h        | Pin Control 30 (PCR30)          | 32                 | RW     | 0000_0000h                  |
| FCCh       | Pin Control 31 (PCR31)          | 32                 | RW     | 0000_0000h                  |

### 11.6.1.2 Version ID (VERID)

#### Offset

| Register | Offset |
|----------|--------|
| VERID    | 0h     |

#### Function

Specifies the version number and feature number of the chip.

#### Diagram



#### Fields

| Field           | Function                                                                                                         |
|-----------------|------------------------------------------------------------------------------------------------------------------|
| 31-24<br>MAJOR  | Major Version Number<br>Indicates the major version number for the specification.                                |
| 23-16<br>MINOR  | Minor Version Number<br>Indicates the minor version number for the specification.                                |
| 15-0<br>FEATURE | Feature Specification Number<br>Indicates the feature set number.<br>0000_0000_0000_0000b - Basic implementation |

### 11.6.1.3 Global Pin Control Low (GPCLR)

#### Offset

| Register | Offset |
|----------|--------|
| GPCLR    | 10h    |

**Function**

Controls writes to the PCR15–PCR0 registers.

**NOTE**

This register supports only 32-bit writes.

**Diagram**

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

**Fields**

| Field                      | Function                                                                                                                                                                                                                                                          |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>GPWE <sub>n</sub> | Global Pin Write Enable<br><br>Configures the corresponding lower 16-bit field of PCR <sub>n</sub> to be updated with the value in the GPWD field.<br>If a selected PCR is locked, the write to that register is ignored.<br><br>0b - Not updated<br>1b - Updated |
| 15-0<br>GPWD               | Global Pin Write Data<br><br>Is written to PCR <sub>n</sub> [15:0] if GPWE <sub>n</sub> = 1.                                                                                                                                                                      |

**11.6.1.4 Global Pin Control High (GPCHR)****Offset**

| Register | Offset |
|----------|--------|
| GPCHR    | 14h    |

**Function**

Controls writes to the PCR31–PCR16 registers.

**NOTE**

This register supports only 32-bit writes.

**Diagram**

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

**Fields**

| Field                      | Function                                                                                                                                                                                                                                                      |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>GPWE <sub>n</sub> | Global Pin Write Enable<br><br>Configures the corresponding lower 16-bit field of PCR <sub>n</sub> to be updated with the value in the GPWD field.<br>If a selected PCR is locked, write to that register is ignored.<br><br>0b - Not updated<br>1b - Updated |
| 15-0<br>GPWD               | Global Pin Write Data<br><br>Is written to PCR <sub>n</sub> [15:0] if GPWE <sub>n</sub> = 1.                                                                                                                                                                  |

**11.6.1.5 Configuration (CONFIG)****Offset**

| Register | Offset |
|----------|--------|
| CONFIG   | 20h    |

**Function**

Configures the port voltage range.

**Diagram**

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

**Fields**

| Field      | Function                                                                                           |
|------------|----------------------------------------------------------------------------------------------------|
| 31-1<br>—  | Reserved                                                                                           |
| 0<br>RANGE | Port Voltage Range<br>Configures the port voltage range.<br>0b - 1.71 V–3.6 V<br>1b - 2.70 V–3.6 V |

**11.6.1.6 Calibration 0 (CALIB0)****Offset**

| Register | Offset |
|----------|--------|
| CALIB0   | 60h    |

**Function**

Stores calibration values for the PMOS and NMOS output drivers when PCR $n$ [DSE] = 0.

**NOTE**

Each module instance supports a different number of registers.

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| PORTE    | —                  | CALIB0                 |
| PORTR    | CALIB0             | —                      |
| PORTR    | —                  | CALIB0                 |

*Table continues on the next page...*

*Table continued from the previous page...*

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| POR3     | CALIB0             | —                      |

### Diagram

|       |    |    |    |    |    |    |    |    |    |    |                |    |    |    |    |      |
|-------|----|----|----|----|----|----|----|----|----|----|----------------|----|----|----|----|------|
| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21             | 20 | 19 | 18 | 17 | 16   |
|       | R  |    |    |    | 0  |    |    |    |    |    |                |    |    |    |    | PCAL |
|       | W  |    |    |    |    |    |    |    |    |    |                |    |    |    |    |      |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | u <sup>1</sup> | u  | u  | u  | u  | u    |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5              | 4  | 3  | 2  | 1  | 0    |
|       | R  |    |    |    | 0  |    |    |    |    |    |                |    |    |    |    | NCAL |
|       | W  |    |    |    |    |    |    |    |    |    |                |    |    |    |    |      |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | u <sup>1</sup> | u  | u  | u  | u  | u    |

1. Reset values are loaded out of IFR.

### Fields

| Field | Function                          |
|-------|-----------------------------------|
| 31-22 | Reserved                          |
| —     |                                   |
| 21-16 | Calibration of PMOS Output Driver |
| PCAL  |                                   |
| 15-6  | Reserved                          |
| —     |                                   |
| 5-0   | Calibration of NMOS Output Driver |
| NCAL  |                                   |

### 11.6.1.7 Calibration 1 (CALIB1)

#### Offset

| Register | Offset |
|----------|--------|
| CALIB1   | 64h    |

#### Function

Stores calibration values for the PMOS and NMOS output drivers when PCR<sub>n</sub>[DSE] = 1.

**NOTE**

Each module instance supports a different number of registers.

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| PORT0    | —                  | CALIB1                 |
| PORT1    | CALIB1             | —                      |
| PORT2    | —                  | CALIB1                 |
| PORT3    | CALIB1             | —                      |

**Diagram**

1. Reset values are loaded out of IFR.

**Fields**

| Field | Function                          |
|-------|-----------------------------------|
| 31-22 | Reserved                          |
| —     |                                   |
| 21-16 | Calibration of PMOS Output Driver |
| PCAL  |                                   |
| 15-6  | Reserved                          |
| —     |                                   |
| 5-0   | Calibration of NMOS Output Driver |
| NCAL  |                                   |

### 11.6.1.8 Pin Control 0 (PCR0)

#### Offset

| Register | Offset |
|----------|--------|
| PCR0     | 80h    |

#### Function

Configures pin control features on each pin.

##### NOTE

Do not modify pin configuration registers associated with pins that are unavailable in your selected package. All unbonded pins unavailable in your package default to the Disabled state for lowest power consumption.

#### Diagram

|       |                                             |    |     |     |     |    |      |     |     |     |     |    |    |    |    |    |
|-------|---------------------------------------------|----|-----|-----|-----|----|------|-----|-----|-----|-----|----|----|----|----|----|
| Bits  | 31                                          | 30 | 29  | 28  | 27  | 26 | 25   | 24  | 23  | 22  | 21  | 20 | 19 | 18 | 17 | 16 |
| R     |                                             |    |     |     |     |    |      |     | 0   |     |     |    |    |    |    |    |
| W     |                                             |    |     |     |     |    |      |     |     |     |     |    |    |    |    |    |
| Reset | See <a href="#">Register reset values</a> . |    |     |     |     |    |      |     |     |     |     |    |    |    |    |    |
| Bits  | 15                                          | 14 | 13  | 12  | 11  | 10 | 9    | 8   | 7   | 6   | 5   | 4  | 3  | 2  | 1  | 0  |
| R     | LK                                          | 0  | INV | IBE | MUX |    | DSE1 | DSE | ODE | PFE | SRE | 0  | PE | PS |    |    |
| W     |                                             |    |     |     |     |    |      |     |     |     |     |    |    |    |    |    |
| Reset | See <a href="#">Register reset values</a> . |    |     |     |     |    |      |     |     |     |     |    |    |    |    |    |

#### Register reset values

| Register | Reset value                                  |
|----------|----------------------------------------------|
| PCR0     | PORT0: 0000_1143h<br>PORT1–PORT3: 0000_0000h |

#### Fields

| Field      | Function                                                                                                             |
|------------|----------------------------------------------------------------------------------------------------------------------|
| 31-16<br>— | Reserved                                                                                                             |
| 15<br>LK   | Lock Register<br>Locks this PCR.<br><br>When a PCR $n$ is locked, its fields cannot be updated until the next reset. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                                                           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |
|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
|                                                                 | 0b - Does not lock<br>1b - Locks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                        |
| 14<br>—                                                         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |
| 13<br>INV                                                       | Invert Input<br>Inverts the digital input.<br>0b - Does not invert<br>1b - Inverts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                        |
| 12<br>IBE                                                       | Input Buffer Enable<br>Enables digital input buffer. When disabled, the digital input is required for analog functions.<br>0b - Disables<br>1b - Enables                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |
| 11-8<br>MUX                                                     | Pin Multiplex Control<br>Configures the multiplexing slots on each pin.<br>Not all pins support all pin multiplexing slots. Unimplemented pin multiplexing slots are reserved.<br>Unimplemented pin multiplexing slots can result in different behaviors, if the unimplemented slot is phantomed (because the module is phantomed on that die) versus unimplemented on the die.<br>The corresponding pin is configured according to the following pin multiplexing slots:<br><br><b>NOTE</b><br>This field is not supported in every instance. The following table includes only supported registers. |                        |
| Instance                                                        | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Field not supported in |
| PORT0                                                           | PCR0[10-8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | PCR0[11]               |
| PORT1                                                           | PCR0[10-8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | PCR0[11]               |
| PORT2                                                           | PCR0[10-8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | PCR0[11]               |
| PORT3                                                           | PCR0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | —                      |
| <b>NOTE</b>                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                        |
| The descriptions of the field settings vary by module instance. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                        |

*Table continued from the previous page...*

| Field | Function |                                                                                                                                                                                                                                                                                                                     |
|-------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Instance | Field value and description                                                                                                                                                                                                                                                                                         |
| PORT0 |          | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific) |
| PORT1 |          | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific) |
| PORT2 |          | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific) |
| PORT3 |          | 0000b - Alternative 0 (GPIO)<br>0001b - Alternative 1 (chip-specific)<br>0010b - Alternative 2 (chip-specific)<br>0011b - Alternative 3 (chip-specific)<br>0100b - Alternative 4 (chip-specific)<br>0101b - Alternative 5 (chip-specific)                                                                           |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                                                                                                                                                                                                                                                                                                                                                                                                              | Function                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                          |          |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------------------|------------------------|-------|---|------|-------|---|------|-------|---|------|-------|------|---|
|                                                                                                                                                                                                                                                                                                                                                                                                                    | Instance                                                                                                                                                                                                                                                                                                                                                                                          | Field value and description                                                                                                                                                                                                                                                                                                              |          |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                   | 0110b - Alternative 6 (chip-specific)<br>0111b - Alternative 7 (chip-specific)<br>1000b - Alternative 8 (chip-specific)<br>1001b - Alternative 9 (chip-specific)<br>1010b - Alternative 10 (chip-specific)<br>1011b - Alternative 11 (chip-specific)<br>1100b - Alternative 12 (chip-specific)<br>1101b - Alternative 13 (chip-specific) |          |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
|                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                          |          |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
| 7<br>DSE1                                                                                                                                                                                                                                                                                                                                                                                                          | Drive Strength Enable<br><br>Configures the drive strength on each pin.<br><br>The drive strength configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>• If this field = 0, normal drive strength is configured on the corresponding pin.</li> <li>• If this field = 1, double drive strength is configured on the corresponding pin.</li> </ul> |                                                                                                                                                                                                                                                                                                                                          |          |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
| <b>NOTE</b><br>This field is not supported in every instance. The following table includes only supported registers.                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                          |          |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
| <table border="1" style="width: 100%; border-collapse: collapse;"> <thead> <tr> <th>Instance</th> <th>Field supported in</th> <th>Field not supported in</th> </tr> </thead> <tbody> <tr> <td>PORT0</td> <td>—</td> <td>PCR0</td> </tr> <tr> <td>PORT1</td> <td>—</td> <td>PCR0</td> </tr> <tr> <td>PORT2</td> <td>—</td> <td>PCR0</td> </tr> <tr> <td>PORT3</td> <td>PCR0</td> <td>—</td> </tr> </tbody> </table> |                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                          | Instance | Field supported in | Field not supported in | PORT0 | — | PCR0 | PORT1 | — | PCR0 | PORT2 | — | PCR0 | PORT3 | PCR0 | — |
| Instance                                                                                                                                                                                                                                                                                                                                                                                                           | Field supported in                                                                                                                                                                                                                                                                                                                                                                                | Field not supported in                                                                                                                                                                                                                                                                                                                   |          |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
| PORT0                                                                                                                                                                                                                                                                                                                                                                                                              | —                                                                                                                                                                                                                                                                                                                                                                                                 | PCR0                                                                                                                                                                                                                                                                                                                                     |          |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
| PORT1                                                                                                                                                                                                                                                                                                                                                                                                              | —                                                                                                                                                                                                                                                                                                                                                                                                 | PCR0                                                                                                                                                                                                                                                                                                                                     |          |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
| PORT2                                                                                                                                                                                                                                                                                                                                                                                                              | —                                                                                                                                                                                                                                                                                                                                                                                                 | PCR0                                                                                                                                                                                                                                                                                                                                     |          |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
| PORT3                                                                                                                                                                                                                                                                                                                                                                                                              | PCR0                                                                                                                                                                                                                                                                                                                                                                                              | —                                                                                                                                                                                                                                                                                                                                        |          |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
| 0b - Normal<br><br>1b - Double                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                          |          |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
| 6<br>DSE                                                                                                                                                                                                                                                                                                                                                                                                           | Drive Strength Enable<br><br>Configures drive strength, low or high, on each pin.<br><br>The drive strength configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>• When this field = 0, low drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul>                                      |                                                                                                                                                                                                                                                                                                                                          |          |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|-------|---|------|-------|------|---|-------|---|------|-------|------|---|
|          | <ul style="list-style-type: none"> <li>When this field = 1, high drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul> <p>0b - Low<br/>1b - High</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                        |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |
| 5<br>ODE | <p>Open Drain Enable</p> <p>Enables open drain output on each pin.</p> <p>The open drain configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the open drain output is disabled on the corresponding pin.</li> <li>When this field = 1, the open drain output is enabled on the corresponding pin, if the pin is configured as a digital output.</li> </ul> <p>0b - Disables<br/>1b - Enables</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                        |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |
| 4<br>PFE | <p>Passive Filter Enable</p> <p>Enables passive input filter on each pin.</p> <p>The passive filter configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the passive input filter is disabled on the corresponding pin.</li> <li>When this field = 1, the passive input filter is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> <p>See the chip's data sheet for filter characteristics.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> <table border="1" style="width: 100%; border-collapse: collapse;"> <thead> <tr> <th>Instance</th> <th>Field supported in</th> <th>Field not supported in</th> </tr> </thead> <tbody> <tr> <td>PORT0</td> <td>—</td> <td>PCR0</td> </tr> <tr> <td>PORT1</td> <td>PCR0</td> <td>—</td> </tr> <tr> <td>PORT2</td> <td>—</td> <td>PCR0</td> </tr> <tr> <td>PORT3</td> <td>PCR0</td> <td>—</td> </tr> </tbody> </table> <p>0b - Disables<br/>1b - Enables</p> | Instance               | Field supported in | Field not supported in | PORT0 | — | PCR0 | PORT1 | PCR0 | — | PORT2 | — | PCR0 | PORT3 | PCR0 | — |
| Instance | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Field not supported in |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |
| PORT0    | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | PCR0                   |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |
| PORT1    | PCR0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | —                      |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |
| PORT2    | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | PCR0                   |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |
| PORT3    | PCR0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | —                      |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |
| 3<br>SRE | <p>Slew Rate Enable</p> <p>Configures the slew rate feature, fast or slow, on each corresponding pin.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                        |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | The slew rate configuration is valid for all digital pin multiplexing modes.<br>0b - Fast<br>1b - Slow                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1<br>PE | Pull Enable<br>Enables the internal pull resistor.<br>This configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, the internal pull resistor is not enabled on the corresponding pin.</li> <li>When this field = 1, the internal pull resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> 0b - Disables<br>1b - Enables                                                                                                                                 |
| 0<br>PS | Pull Select<br>Enables the internal pullup or pulldown resistor.<br>This configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, the internal pulldown resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> <li>When this field = 1, the internal pullup resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> </ul> 0b - Enables internal pulldown resistor<br>1b - Enables internal pullup resistor |

### 11.6.1.9 Pin Control 1 (PCR1)

#### Offset

| Register | Offset |
|----------|--------|
| PCR1     | 84h    |

#### Function

Configures pin control features on each pin.

#### NOTE

Do not modify pin configuration registers associated with pins that are unavailable in your selected package. All unbonded pins unavailable in your package default to the Disabled state for lowest power consumption.

**Diagram**Reset See [Register reset values](#).Reset See [Register reset values](#).**Register reset values**

| Register | Reset value                                  |
|----------|----------------------------------------------|
| PCR1     | PORT0: 0000_1102h<br>PORT1–PORT3: 0000_0000h |

**Fields**

| Field      | Function                                                                                                                                                     |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>— | Reserved                                                                                                                                                     |
| 15<br>LK   | Lock Register<br>Locks this PCR.<br><br>When a PCR $n$ is locked, its fields cannot be updated until the next reset.<br><br>0b - Does not lock<br>1b - Locks |
| 14<br>—    | Reserved                                                                                                                                                     |
| 13<br>INV  | Invert Input<br>Inverts the digital input.<br><br>0b - Does not invert<br>1b - Inverts                                                                       |
| 12<br>IBE  | Input Buffer Enable<br>Enables digital input buffer. When disabled, the digital input is required for analog functions.<br><br>0b - Disables                 |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                        |                    |                        |       |            |          |       |            |          |       |            |          |       |      |   |          |                             |       |                                                                                                                                                                                                                                                                                                                     |       |                                                                                                             |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|-------|------------|----------|-------|------------|----------|-------|------------|----------|-------|------|---|----------|-----------------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------------------------------------------------------------------------------------------------------------|
|          | <p>1b - Enables</p> <p>11-8<br/>MUX</p> <p>Pin Multiplex Control</p> <p>Configures the multiplexing slots on each pin.</p> <p>Not all pins support all pin multiplexing slots. Unimplemented pin multiplexing slots are reserved.</p> <p>Unimplemented pin multiplexing slots can result in different behaviors, if the unimplemented slot is phantomed (because the module is phantomed on that die) versus unimplemented on the die.</p> <p>The corresponding pin is configured according to the following pin multiplexing slots:</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                        |                    |                        |       |            |          |       |            |          |       |            |          |       |      |   |          |                             |       |                                                                                                                                                                                                                                                                                                                     |       |                                                                                                             |
|          | <table border="1"> <thead> <tr> <th>Instance</th><th>Field supported in</th><th>Field not supported in</th></tr> </thead> <tbody> <tr> <td>PORTE</td><td>PCR1[10-8]</td><td>PCR1[11]</td></tr> <tr> <td>PORT1</td><td>PCR1[10-8]</td><td>PCR1[11]</td></tr> <tr> <td>PORT2</td><td>PCR1[10-8]</td><td>PCR1[11]</td></tr> <tr> <td>PORT3</td><td>PCR1</td><td>—</td></tr> </tbody> </table> <p style="text-align: center;"><b>NOTE</b></p> <p>The descriptions of the field settings vary by module instance.</p> <table border="1"> <thead> <tr> <th>Instance</th><th>Field value and description</th></tr> </thead> <tbody> <tr> <td>PORTE</td><td>           000b - Alternative 0 (GPIO)<br/>           001b - Alternative 1 (chip-specific)<br/>           010b - Alternative 2 (chip-specific)<br/>           011b - Alternative 3 (chip-specific)<br/>           100b - Alternative 4 (chip-specific)<br/>           101b - Alternative 5 (chip-specific)<br/>           110b - Alternative 6 (chip-specific)<br/>           111b - Alternative 7 (chip-specific)         </td></tr> <tr> <td>PORT1</td><td>           000b - Alternative 0 (GPIO)<br/>           001b - Alternative 1 (chip-specific)<br/>           010b - Alternative 2 (chip-specific)         </td></tr> </tbody> </table> | Instance               | Field supported in | Field not supported in | PORTE | PCR1[10-8] | PCR1[11] | PORT1 | PCR1[10-8] | PCR1[11] | PORT2 | PCR1[10-8] | PCR1[11] | PORT3 | PCR1 | — | Instance | Field value and description | PORTE | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific) | PORT1 | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific) |
| Instance | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Field not supported in |                    |                        |       |            |          |       |            |          |       |            |          |       |      |   |          |                             |       |                                                                                                                                                                                                                                                                                                                     |       |                                                                                                             |
| PORTE    | PCR1[10-8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | PCR1[11]               |                    |                        |       |            |          |       |            |          |       |            |          |       |      |   |          |                             |       |                                                                                                                                                                                                                                                                                                                     |       |                                                                                                             |
| PORT1    | PCR1[10-8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | PCR1[11]               |                    |                        |       |            |          |       |            |          |       |            |          |       |      |   |          |                             |       |                                                                                                                                                                                                                                                                                                                     |       |                                                                                                             |
| PORT2    | PCR1[10-8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | PCR1[11]               |                    |                        |       |            |          |       |            |          |       |            |          |       |      |   |          |                             |       |                                                                                                                                                                                                                                                                                                                     |       |                                                                                                             |
| PORT3    | PCR1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | —                      |                    |                        |       |            |          |       |            |          |       |            |          |       |      |   |          |                             |       |                                                                                                                                                                                                                                                                                                                     |       |                                                                                                             |
| Instance | Field value and description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                        |                    |                        |       |            |          |       |            |          |       |            |          |       |      |   |          |                             |       |                                                                                                                                                                                                                                                                                                                     |       |                                                                                                             |
| PORTE    | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                        |                    |                        |       |            |          |       |            |          |       |            |          |       |      |   |          |                             |       |                                                                                                                                                                                                                                                                                                                     |       |                                                                                                             |
| PORT1    | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                        |                    |                        |       |            |          |       |            |          |       |            |          |       |      |   |          |                             |       |                                                                                                                                                                                                                                                                                                                     |       |                                                                                                             |

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | Instance                                                                                                                                                         | Field value and description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|           |                                                                                                                                                                  | 011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific)                                                                                                                                                                                                                                                                                                                                                                                  |
|           | PORTR2                                                                                                                                                           | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific)                                                                                                                                                                                                                                                                   |
|           | PORTR3                                                                                                                                                           | 0000b - Alternative 0 (GPIO)<br>0001b - Alternative 1 (chip-specific)<br>0010b - Alternative 2 (chip-specific)<br>0011b - Alternative 3 (chip-specific)<br>0100b - Alternative 4 (chip-specific)<br>0101b - Alternative 5 (chip-specific)<br>0110b - Alternative 6 (chip-specific)<br>0111b - Alternative 7 (chip-specific)<br>1000b - Alternative 8 (chip-specific)<br>1001b - Alternative 9 (chip-specific)<br>1010b - Alternative 10 (chip-specific)<br>1011b - Alternative 11 (chip-specific)<br>1100b - Alternative 12 (chip-specific)<br>1101b - Alternative 13 (chip-specific) |
| 7<br>DSE1 | Drive Strength Enable<br><br>Configures the drive strength on each pin.<br><br>The drive strength configuration is valid for all digital pin multiplexing modes. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                        |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|-------|---|------|-------|---|------|-------|---|------|-------|------|---|
|          | <ul style="list-style-type: none"> <li>If this field = 0, normal drive strength is configured on the corresponding pin.</li> <li>If this field = 1, double drive strength is configured on the corresponding pin.</li> </ul> <p style="text-align: center;"><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> <table border="1" style="width: 100%; border-collapse: collapse;"> <thead> <tr> <th>Instance</th><th>Field supported in</th><th>Field not supported in</th></tr> </thead> <tbody> <tr> <td>PORT0</td><td>—</td><td>PCR1</td></tr> <tr> <td>PORT1</td><td>—</td><td>PCR1</td></tr> <tr> <td>PORT2</td><td>—</td><td>PCR1</td></tr> <tr> <td>PORT3</td><td>PCR1</td><td>—</td></tr> </tbody> </table> <p style="text-align: center;">0b - Normal<br/>1b - Double</p> | Instance               | Field supported in | Field not supported in | PORT0 | — | PCR1 | PORT1 | — | PCR1 | PORT2 | — | PCR1 | PORT3 | PCR1 | — |
| Instance | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Field not supported in |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
| PORT0    | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | PCR1                   |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
| PORT1    | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | PCR1                   |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
| PORT2    | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | PCR1                   |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
| PORT3    | PCR1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | —                      |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
| 6<br>DSE | <p>Drive Strength Enable</p> <p>Configures drive strength, low or high, on each pin.</p> <p>The drive strength configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, low drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> <li>When this field = 1, high drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul> <p style="text-align: center;">0b - Low<br/>1b - High</p>                                                                                                                                                                                                                                                                                         |                        |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
| 5<br>ODE | <p>Open Drain Enable</p> <p>Enables open drain output on each pin.</p> <p>The open drain configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the open drain output is disabled on the corresponding pin.</li> <li>When this field = 1, the open drain output is enabled on the corresponding pin, if the pin is configured as a digital output.</li> </ul> <p style="text-align: center;">0b - Disables<br/>1b - Enables</p>                                                                                                                                                                                                                                                                                                                                                     |                        |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |
| 4<br>PFE | <p>Passive Filter Enable</p> <p>Enables passive input filter on each pin.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                        |                    |                        |       |   |      |       |   |      |       |   |      |       |      |   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                        |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|-------|---|------|-------|------|---|-------|---|------|-------|------|---|
|          | <p>The passive filter configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>• When this field = 0, the passive input filter is disabled on the corresponding pin.</li> <li>• When this field = 1, the passive input filter is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> <p>See the chip's data sheet for filter characteristics.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> <table border="1" style="width: 100%; border-collapse: collapse;"> <thead> <tr> <th>Instance</th><th>Field supported in</th><th>Field not supported in</th></tr> </thead> <tbody> <tr> <td>PORTE</td><td>—</td><td>PCR1</td></tr> <tr> <td>PORTE</td><td>PCR1</td><td>—</td></tr> <tr> <td>PORTE</td><td>—</td><td>PCR1</td></tr> <tr> <td>PORTE</td><td>PCR1</td><td>—</td></tr> </tbody> </table> <p style="margin-left: 40px;">0b - Disables<br/>1b - Enables</p> | Instance               | Field supported in | Field not supported in | PORTE | — | PCR1 | PORTE | PCR1 | — | PORTE | — | PCR1 | PORTE | PCR1 | — |
| Instance | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Field not supported in |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |
| PORTE    | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | PCR1                   |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |
| PORTE    | PCR1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | —                      |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |
| PORTE    | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | PCR1                   |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |
| PORTE    | PCR1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | —                      |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |
| 3<br>SRE | <p>Slew Rate Enable</p> <p>Configures the slew rate feature, fast or slow, on each corresponding pin.</p> <p>The slew rate configuration is valid for all digital pin multiplexing modes.</p> <p style="margin-left: 40px;">0b - Fast<br/>1b - Slow</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                        |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |
| 2<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                        |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |
| 1<br>PE  | <p>Pull Enable</p> <p>Enables the internal pull resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>• When this field = 0, the internal pull resistor is not enabled on the corresponding pin.</li> <li>• When this field = 1, the internal pull resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> <p style="margin-left: 40px;">0b - Disables<br/>1b - Enables</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                        |                    |                        |       |   |      |       |      |   |       |   |      |       |      |   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>PS | <p>Pull Select</p> <p>Enables the internal pullup or pulldown resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pulldown resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> <li>When this field = 1, the internal pullup resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> </ul> <p>0b - Enables internal pulldown resistor</p> <p>1b - Enables internal pullup resistor</p> |

#### 11.6.1.10 Pin Control 2 (PCR2)

##### Offset

| Register | Offset |
|----------|--------|
| PCR2     | 88h    |

##### Function

Configures pin control features on each pin.

##### NOTE

Do not modify pin configuration registers associated with pins that are unavailable in your selected package. All unbonded pins unavailable in your package default to the Disabled state for lowest power consumption.

##### Diagram

| Bits | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| R    |    |    |    |    |    |    |    |    | 0  |    |    |    |    |    |    |    |
| W    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

Reset [See Register reset values.](#)

  

| Bits | 15 | 14 | 13  | 12  | 11  | 10 | 9 | 8 | 7 | 6   | 5   | 4 | 3   | 2 | 1  | 0  |
|------|----|----|-----|-----|-----|----|---|---|---|-----|-----|---|-----|---|----|----|
| R    | LK | 0  | INV | IBE | MUX |    |   |   | 0 | DSE | ODE | 0 | SRE | 0 | PE | PS |
| W    |    |    |     |     |     |    |   |   |   |     |     |   |     |   |    |    |

Reset [See Register reset values.](#)

## Register reset values

| Register | Reset value                                  |
|----------|----------------------------------------------|
| PCR2     | PORT0: 0000_0140h<br>PORT1–PORT3: 0000_0000h |

## Fields

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15<br>LK    | <p>Lock Register</p> <p>Locks this PCR.</p> <p>When a PCR<math>n</math> is locked, its fields cannot be updated until the next reset.</p> <p>0b - Does not lock<br/>1b - Locks</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 14<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 13<br>INV   | <p>Invert Input</p> <p>Inverts the digital input.</p> <p>0b - Does not invert<br/>1b - Inverts</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 12<br>IBE   | <p>Input Buffer Enable</p> <p>Enables digital input buffer. When disabled, the digital input is required for analog functions.</p> <p>0b - Disables<br/>1b - Enables</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 11-8<br>MUX | <p>Pin Multiplex Control</p> <p>Configures the multiplexing slots on each pin.</p> <p>Not all pins support all pin multiplexing slots. Unimplemented pin multiplexing slots are reserved.</p> <p>Unimplemented pin multiplexing slots can result in different behaviors, if the unimplemented slot is phantomed (because the module is phantomed on that die) versus unimplemented on the die.</p> <p>The corresponding pin is configured according to the following pin multiplexing slots:</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> |

| Field                                                           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                    |                        |
|-----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------------------|
|                                                                 | Instance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Field supported in | Field not supported in |
| PORT0                                                           | PCR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | —                  |                        |
| PORT1                                                           | PCR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | —                  |                        |
| PORT2                                                           | PCR2[10–8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | PCR2[11]           |                        |
| PORT3                                                           | PCR2[9–8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | PCR2[11–10]        |                        |
| <b>NOTE</b>                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                    |                        |
| The descriptions of the field settings vary by module instance. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                    |                        |
| Instance                                                        | Field value and description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                    |                        |
| PORT0                                                           | 0000b - Alternative 0 (GPIO)<br>0001b - Alternative 1 (chip-specific)<br>0010b - Alternative 2 (chip-specific)<br>0011b - Alternative 3 (chip-specific)<br>0100b - Alternative 4 (chip-specific)<br>0101b - Alternative 5 (chip-specific)<br>0110b - Alternative 6 (chip-specific)<br>0111b - Alternative 7 (chip-specific)<br>1000b - Alternative 8 (chip-specific)<br>1001b - Alternative 9 (chip-specific)<br>1010b - Alternative 10 (chip-specific)<br>1011b - Alternative 11 (chip-specific)<br>1100b - Alternative 12 (chip-specific) |                    |                        |
| PORT1                                                           | 0000b - Alternative 0 (GPIO)<br>0001b - Alternative 1 (chip-specific)<br>0010b - Alternative 2 (chip-specific)<br>0011b - Alternative 3 (chip-specific)<br>0100b - Alternative 4 (chip-specific)<br>0101b - Alternative 5 (chip-specific)<br>0110b - Alternative 6 (chip-specific)<br>0111b - Alternative 7 (chip-specific)                                                                                                                                                                                                                 |                    |                        |

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                     |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | Instance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Field value and description                                                                                                                                                                                                                                                                                         |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1000b - Alternative 8 (chip-specific)<br>1001b - Alternative 9 (chip-specific)<br>1010b - Alternative 10 (chip-specific)<br>1011b - Alternative 11 (chip-specific)<br>1100b - Alternative 12 (chip-specific)                                                                                                        |
|          | POR2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific) |
|          | POR3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 00b - Alternative 0 (GPIO)<br>01b - Alternative 1 (chip-specific)<br>10b - Alternative 2 (chip-specific)<br>11b - Alternative 3 (chip-specific)                                                                                                                                                                     |
| 7<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                     |
| 6<br>DSE | Drive Strength Enable<br><br>Configures drive strength, low or high, on each pin.<br><br>The drive strength configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>• When this field = 0, low drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> <li>• When this field = 1, high drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul> 0b - Low<br>1b - High |                                                                                                                                                                                                                                                                                                                     |
| 5<br>ODE | Open Drain Enable<br><br>Enables open drain output on each pin.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | <p>The open drain configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the open drain output is disabled on the corresponding pin.</li> <li>When this field = 1, the open drain output is enabled on the corresponding pin, if the pin is configured as a digital output.</li> </ul> <p>0b - Disables<br/>1b - Enables</p>                                                                                                                                                                                                 |
| 4<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3<br>SRE | <p>Slew Rate Enable</p> <p>Configures the slew rate feature, fast or slow, on each corresponding pin.</p> <p>The slew rate configuration is valid for all digital pin multiplexing modes.</p> <p>0b - Fast<br/>1b - Slow</p>                                                                                                                                                                                                                                                                                                                                                                         |
| 2<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1<br>PE  | <p>Pull Enable</p> <p>Enables the internal pull resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pull resistor is not enabled on the corresponding pin.</li> <li>When this field = 1, the internal pull resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> <p>0b - Disables<br/>1b - Enables</p>                                                                                                                                 |
| 0<br>PS  | <p>Pull Select</p> <p>Enables the internal pullup or pulldown resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pulldown resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> <li>When this field = 1, the internal pullup resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> </ul> <p>0b - Enables internal pulldown resistor<br/>1b - Enables internal pullup resistor</p> |

### 11.6.1.11 Pin Control 3 (PCR3)

## Offset

| Register | Offset |
|----------|--------|
| PCR3     | 8Ch    |

## Function

Configures pin control features on each pin.

## NOTE

Do not modify pin configuration registers associated with pins that are unavailable in your selected package. All unbonded pins unavailable in your package default to the Disabled state for lowest power consumption.

## NOTE

Each module instance supports a different number of registers.

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| PORT0    | PCR3               | —                      |
| PORT1    | PCR3               | —                      |
| PORT2    | PCR3               | —                      |
| PORT3    | —                  | PCR3                   |

## Diagram



[Reset](#) See [Register reset values](#)



[See Register reset values](#)

#### Register reset values

| Register | Reset value                                                                   |
|----------|-------------------------------------------------------------------------------|
| PCR3     | PORT0: 0000_1103h<br>PORT1,PORT2: 0000_0000h<br>PORT3: Register not supported |

**Fields**

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                        |                    |                        |       |      |   |       |            |          |       |      |   |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|-------|------|---|-------|------------|----------|-------|------|---|
| 31-16<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                        |                    |                        |       |      |   |       |            |          |       |      |   |
| 15<br>LK    | <p>Lock Register</p> <p>Locks this PCR.</p> <p>When a PCR<math>n</math> is locked, its fields cannot be updated until the next reset.</p> <p>0b - Does not lock<br/>1b - Locks</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                        |                    |                        |       |      |   |       |            |          |       |      |   |
| 14<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                        |                    |                        |       |      |   |       |            |          |       |      |   |
| 13<br>INV   | <p>Invert Input</p> <p>Inverts the digital input.</p> <p>0b - Does not invert<br/>1b - Inverts</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                        |                    |                        |       |      |   |       |            |          |       |      |   |
| 12<br>IBE   | <p>Input Buffer Enable</p> <p>Enables digital input buffer. When disabled, the digital input is required for analog functions.</p> <p>0b - Disables<br/>1b - Enables</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                        |                    |                        |       |      |   |       |            |          |       |      |   |
| 11-8<br>MUX | <p>Pin Multiplex Control</p> <p>Configures the multiplexing slots on each pin.</p> <p>Not all pins support all pin multiplexing slots. Unimplemented pin multiplexing slots are reserved.</p> <p>Unimplemented pin multiplexing slots can result in different behaviors, if the unimplemented slot is phantomed (because the module is phantomed on that die) versus unimplemented on the die.</p> <p>The corresponding pin is configured according to the following pin multiplexing slots:</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> <table border="1" style="width: 100%; border-collapse: collapse;"> <thead> <tr> <th>Instance</th> <th>Field supported in</th> <th>Field not supported in</th> </tr> </thead> <tbody> <tr> <td>PORT0</td> <td>PCR3</td> <td>—</td> </tr> <tr> <td>PORT1</td> <td>PCR3[10-8]</td> <td>PCR3[11]</td> </tr> <tr> <td>PORT2</td> <td>PCR3</td> <td>—</td> </tr> </tbody> </table> | Instance               | Field supported in | Field not supported in | PORT0 | PCR3 | — | PORT1 | PCR3[10-8] | PCR3[11] | PORT2 | PCR3 | — |
| Instance    | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Field not supported in |                    |                        |       |      |   |       |            |          |       |      |   |
| PORT0       | PCR3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | —                      |                    |                        |       |      |   |       |            |          |       |      |   |
| PORT1       | PCR3[10-8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | PCR3[11]               |                    |                        |       |      |   |       |            |          |       |      |   |
| PORT2       | PCR3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | —                      |                    |                        |       |      |   |       |            |          |       |      |   |

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <b>NOTE</b><br>The descriptions of the field settings vary by module instance.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|       | <b>Instance</b> <b>Field value and description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       | PORT0<br>0000b - Alternative 0 (GPIO)<br>0001b - Alternative 1 (chip-specific)<br>0010b - Alternative 2 (chip-specific)<br>0011b - Alternative 3 (chip-specific)<br>0100b - Alternative 4 (chip-specific)<br>0101b - Alternative 5 (chip-specific)<br>0110b - Alternative 6 (chip-specific)<br>0111b - Alternative 7 (chip-specific)<br>1000b - Alternative 8 (chip-specific)<br>1001b - Alternative 9 (chip-specific)<br>1010b - Alternative 10 (chip-specific)<br>1011b - Alternative 11 (chip-specific)<br>1100b - Alternative 12 (chip-specific) |
|       | PORT1<br>000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific)                                                                                                                                                                                                                         |
|       | PORT2<br>0000b - Alternative 0 (GPIO)<br>0001b - Alternative 1 (chip-specific)<br>0010b - Alternative 2 (chip-specific)<br>0011b - Alternative 3 (chip-specific)<br>0100b - Alternative 4 (chip-specific)<br>0101b - Alternative 5 (chip-specific)<br>0110b - Alternative 6 (chip-specific)                                                                                                                                                                                                                                                          |

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                 |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | Instance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Field value and description                                                                                                                                                                                                                                                                     |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0111b - Alternative 7 (chip-specific)<br>1000b - Alternative 8 (chip-specific)<br>1001b - Alternative 9 (chip-specific)<br>1010b - Alternative 10 (chip-specific)<br>1011b - Alternative 11 (chip-specific)<br>1100b - Alternative 12 (chip-specific)<br>1101b - Alternative 13 (chip-specific) |
| 7<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                 |
| 6<br>DSE | <b>Drive Strength Enable</b><br>Configures drive strength, low or high, on each pin.<br>The drive strength configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, low drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> <li>When this field = 1, high drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul> 0b - Low<br>1b - High |                                                                                                                                                                                                                                                                                                 |
| 5<br>ODE | <b>Open Drain Enable</b><br>Enables open drain output on each pin.<br>The open drain configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, the open drain output is disabled on the corresponding pin.</li> <li>When this field = 1, the open drain output is enabled on the corresponding pin, if the pin is configured as a digital output.</li> </ul> 0b - Disables<br>1b - Enables                                                             |                                                                                                                                                                                                                                                                                                 |
| 4<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                 |
| 3<br>SRE | <b>Slew Rate Enable</b><br>Configures the slew rate feature, fast or slow, on each corresponding pin.                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                 |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | The slew rate configuration is valid for all digital pin multiplexing modes.<br>0b - Fast<br>1b - Slow                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1<br>PE | Pull Enable<br>Enables the internal pull resistor.<br>This configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, the internal pull resistor is not enabled on the corresponding pin.</li> <li>When this field = 1, the internal pull resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> 0b - Disables<br>1b - Enables                                                                                                                                 |
| 0<br>PS | Pull Select<br>Enables the internal pullup or pulldown resistor.<br>This configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, the internal pulldown resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> <li>When this field = 1, the internal pullup resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> </ul> 0b - Enables internal pulldown resistor<br>1b - Enables internal pullup resistor |

#### 11.6.1.12 Pin Control a (PCR4 - PCR6)

##### Offset

| Register | Offset |
|----------|--------|
| PCR4     | 90h    |
| PCR5     | 94h    |
| PCR6     | 98h    |

##### Function

Configures pin control features on each pin.

**NOTE**

Do not modify pin configuration registers associated with pins that are unavailable in your selected package. All unbonded pins unavailable in your package default to the Disabled state for lowest power consumption.

**NOTE**

Each module instance supports a different number of registers.

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| PORT0    | PCR6               | PCR4–PCR5              |
| PORT1    | PCR4–PCR6          | —                      |
| PORT2    | PCR4–PCR6          | —                      |
| PORT3    | PCR6               | PCR4–PCR5              |

**Diagram**

|                                             |    |    |     |     |     |    |    |    |    |     |     |    |     |    |    |    |
|---------------------------------------------|----|----|-----|-----|-----|----|----|----|----|-----|-----|----|-----|----|----|----|
| Bits                                        | 31 | 30 | 29  | 28  | 27  | 26 | 25 | 24 | 23 | 22  | 21  | 20 | 19  | 18 | 17 | 16 |
| R                                           |    |    |     |     |     |    |    |    | 0  |     |     |    |     |    |    |    |
| W                                           |    |    |     |     |     |    |    |    |    |     |     |    |     |    |    |    |
| Reset                                       |    |    |     |     |     |    |    |    |    |     |     |    |     |    |    |    |
| See <a href="#">Register reset values</a> . |    |    |     |     |     |    |    |    |    |     |     |    |     |    |    |    |
| Bits                                        | 15 | 14 | 13  | 12  | 11  | 10 | 9  | 8  | 7  | 6   | 5   | 4  | 3   | 2  | 1  | 0  |
| R                                           | LK | 0  | INV | IBE | MUX |    |    |    | 0  | DSE | ODE | 0  | SRE | 0  | PE | PS |
| W                                           |    |    |     |     |     |    |    |    |    |     |     |    |     |    |    |    |
| Reset                                       |    |    |     |     |     |    |    |    |    |     |     |    |     |    |    |    |
| See <a href="#">Register reset values</a> . |    |    |     |     |     |    |    |    |    |     |     |    |     |    |    |    |

**Register reset values**

| Register  | Reset value                                                                               |
|-----------|-------------------------------------------------------------------------------------------|
| PCR4–PCR5 | PORT0: Register not supported<br>PORT1,PORT2: 0000_0000h<br>PORT3: Register not supported |
| PCR6      | PORT0–PORT3: 0000_0000h                                                                   |

**Fields**

| Field | Function |
|-------|----------|
| 31-16 | Reserved |
| —     |          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                        |                    |                        |       |      |   |       |           |   |       |                 |               |       |      |   |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|-------|------|---|-------|-----------|---|-------|-----------------|---------------|-------|------|---|
| 15<br>LK    | Lock Register<br>Locks this PCR.<br>When a PCR $n$ is locked, its fields cannot be updated until the next reset.<br>0b - Does not lock<br>1b - Locks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                        |                    |                        |       |      |   |       |           |   |       |                 |               |       |      |   |
| 14<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                        |                    |                        |       |      |   |       |           |   |       |                 |               |       |      |   |
| 13<br>INV   | Invert Input<br>Inverts the digital input.<br>0b - Does not invert<br>1b - Inverts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |                    |                        |       |      |   |       |           |   |       |                 |               |       |      |   |
| 12<br>IBE   | Input Buffer Enable<br>Enables digital input buffer. When disabled, the digital input is required for analog functions.<br>0b - Disables<br>1b - Enables                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                        |                    |                        |       |      |   |       |           |   |       |                 |               |       |      |   |
| 11-8<br>MUX | Pin Multiplex Control<br>Configures the multiplexing slots on each pin.<br>Not all pins support all pin multiplexing slots. Unimplemented pin multiplexing slots are reserved.<br>Unimplemented pin multiplexing slots can result in different behaviors, if the unimplemented slot is phantomed (because the module is phantomed on that die) versus unimplemented on the die.<br>The corresponding pin is configured according to the following pin multiplexing slots:<br><div style="text-align: center;"> <b>NOTE</b><br/>           This field is not supported in every instance. The following table includes only supported registers.         </div> <table border="1" style="width: 100%; border-collapse: collapse; margin-top: 10px;"> <thead> <tr> <th>Instance</th> <th>Field supported in</th> <th>Field not supported in</th> </tr> </thead> <tbody> <tr> <td>PORT0</td> <td>PCR6</td> <td>—</td> </tr> <tr> <td>PORT1</td> <td>PCR4-PCR6</td> <td>—</td> </tr> <tr> <td>PORT2</td> <td>PCR4-PCR6[10-8]</td> <td>PCR4-PCR6[11]</td> </tr> <tr> <td>PORT3</td> <td>PCR6</td> <td>—</td> </tr> </tbody> </table> | Instance               | Field supported in | Field not supported in | PORT0 | PCR6 | — | PORT1 | PCR4-PCR6 | — | PORT2 | PCR4-PCR6[10-8] | PCR4-PCR6[11] | PORT3 | PCR6 | — |
| Instance    | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Field not supported in |                    |                        |       |      |   |       |           |   |       |                 |               |       |      |   |
| PORT0       | PCR6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | —                      |                    |                        |       |      |   |       |           |   |       |                 |               |       |      |   |
| PORT1       | PCR4-PCR6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | —                      |                    |                        |       |      |   |       |           |   |       |                 |               |       |      |   |
| PORT2       | PCR4-PCR6[10-8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PCR4-PCR6[11]          |                    |                        |       |      |   |       |           |   |       |                 |               |       |      |   |
| PORT3       | PCR6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | —                      |                    |                        |       |      |   |       |           |   |       |                 |               |       |      |   |

*Table continued from the previous page...*

| Field                                                                          | Function  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|--------------------------------------------------------------------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <b>NOTE</b><br>The descriptions of the field settings vary by module instance. |           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| Instance                                                                       | Register  | Field value and description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| PORT0                                                                          | PCR4–PCR5 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| PORT3                                                                          | PCR4–PCR5 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| PORT0                                                                          | PCR6      | 0000b - Alternative 0 (GPIO)<br>0001b - Alternative 1 (chip-specific)<br>0010b - Alternative 2 (chip-specific)<br>0011b - Alternative 3 (chip-specific)<br>0100b - Alternative 4 (chip-specific)<br>0101b - Alternative 5 (chip-specific)<br>0110b - Alternative 6 (chip-specific)<br>0111b - Alternative 7 (chip-specific)<br>1000b - Alternative 8 (chip-specific)<br>1001b - Alternative 9 (chip-specific)<br>1010b - Alternative 10 (chip-specific)<br>1011b - Alternative 11 (chip-specific)<br>1100b - Alternative 12 (chip-specific) |  |
| PORT1                                                                          | PCR4–PCR6 | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific)                                                                                                                                                                                                                         |  |
| PORT2                                                                          | PCR4–PCR6 | 0000b - Alternative 0 (GPIO)<br>0001b - Alternative 1 (chip-specific)<br>0010b - Alternative 2 (chip-specific)<br>0011b - Alternative 3 (chip-specific)<br>0100b - Alternative 4 (chip-specific)<br>0101b - Alternative 5 (chip-specific)<br>0110b - Alternative 6 (chip-specific)<br>0111b - Alternative 7 (chip-specific)                                                                                                                                                                                                                 |  |
| PORT3                                                                          | PCR6      | 0000b - Alternative 0 (GPIO)<br>0001b - Alternative 1 (chip-specific)<br>0010b - Alternative 2 (chip-specific)<br>0011b - Alternative 3 (chip-specific)                                                                                                                                                                                                                                                                                                                                                                                     |  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | Instance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Register | Field value and description                                                                                                                                                                                                                                                                                                                                                                                                |
|          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          | 0100b - Alternative 4 (chip-specific)<br>0101b - Alternative 5 (chip-specific)<br>0110b - Alternative 6 (chip-specific)<br>0111b - Alternative 7 (chip-specific)<br>1000b - Alternative 8 (chip-specific)<br>1001b - Alternative 9 (chip-specific)<br>1010b - Alternative 10 (chip-specific)<br>1011b - Alternative 11 (chip-specific)<br>1100b - Alternative 12 (chip-specific)<br>1101b - Alternative 13 (chip-specific) |
| 7        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |                                                                                                                                                                                                                                                                                                                                                                                                                            |
| —        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6<br>DSE | Drive Strength Enable<br><br>Configures drive strength, low or high, on each pin.<br><br>The drive strength configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>• When this field = 0, low drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> <li>• When this field = 1, high drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul> 0b - Low<br>1b - High |          |                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5<br>ODE | Open Drain Enable<br><br>Enables open drain output on each pin.<br><br>The open drain configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>• When this field = 0, the open drain output is disabled on the corresponding pin.</li> <li>• When this field = 1, the open drain output is enabled on the corresponding pin, if the pin is configured as a digital output.</li> </ul> 0b - Disables<br>1b - Enables                                                             |          |                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 4        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |                                                                                                                                                                                                                                                                                                                                                                                                                            |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3<br>SRE | <p>Slew Rate Enable</p> <p>Configures the slew rate feature, fast or slow, on each corresponding pin.</p> <p>The slew rate configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>0b - Fast</li> <li>1b - Slow</li> </ul>                                                                                                                                                                                                                                                                                                                                                                             |
| 2<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1<br>PE  | <p>Pull Enable</p> <p>Enables the internal pull resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>• When this field = 0, the internal pull resistor is not enabled on the corresponding pin.</li> <li>• When this field = 1, the internal pull resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> <ul style="list-style-type: none"> <li>0b - Disables</li> <li>1b - Enables</li> </ul>                                                                                                                                 |
| 0<br>PS  | <p>Pull Select</p> <p>Enables the internal pullup or pulldown resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>• When this field = 0, the internal pulldown resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> <li>• When this field = 1, the internal pullup resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> </ul> <ul style="list-style-type: none"> <li>0b - Enables internal pulldown resistor</li> <li>1b - Enables internal pullup resistor</li> </ul> |

### 11.6.1.13 Pin Control 7 (PCR7)

#### Offset

| Register | Offset |
|----------|--------|
| PCR7     | 9Ch    |

#### Function

Configures pin control features on each pin.

**NOTE**

Do not modify pin configuration registers associated with pins that are unavailable in your selected package. All unbonded pins unavailable in your package default to the Disabled state for lowest power consumption.

**NOTE**

Each module instance supports a different number of registers.

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| PORT0    | —                  | PCR7                   |
| PORT1    | PCR7               | —                      |
| PORT2    | PCR7               | —                      |
| PORT3    | PCR7               | —                      |

**Diagram****Fields**

| Field      | Function                                                                                                                                             |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>— | Reserved                                                                                                                                             |
| 15<br>LK   | Lock Register<br>Locks this PCR.<br>When a PCR $n$ is locked, its fields cannot be updated until the next reset.<br>0b - Does not lock<br>1b - Locks |
| 14<br>—    | Reserved                                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |                             |                        |                                                                                                                                                                                                  |      |   |      |            |          |      |            |          |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-----------------------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---|------|------------|----------|------|------------|----------|
| 13<br>INV   | Invert Input<br><br>Inverts the digital input.<br><br>0b - Does not invert<br>1b - Inverts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                        |                             |                        |                                                                                                                                                                                                  |      |   |      |            |          |      |            |          |
| 12<br>IBE   | Input Buffer Enable<br><br>Enables digital input buffer. When disabled, the digital input is required for analog functions.<br><br>0b - Disables<br>1b - Enables                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                        |                             |                        |                                                                                                                                                                                                  |      |   |      |            |          |      |            |          |
| 11-8<br>MUX | Pin Multiplex Control<br><br>Configures the multiplexing slots on each pin.<br><br>Not all pins support all pin multiplexing slots. Unimplemented pin multiplexing slots are reserved.<br><br>Unimplemented pin multiplexing slots can result in different behaviors, if the unimplemented slot is phantomed (because the module is phantomed on that die) versus unimplemented on the die.<br><br>The corresponding pin is configured according to the following pin multiplexing slots:<br><br><b>NOTE</b><br>This field is not supported in every instance. The following table includes only supported registers. |                        |                             |                        |                                                                                                                                                                                                  |      |   |      |            |          |      |            |          |
|             | <table border="1"> <thead> <tr> <th>Instance</th><th>Field supported in</th><th>Field not supported in</th></tr> </thead> <tbody> <tr> <td>POR1</td><td>PCR7</td><td>—</td></tr> <tr> <td>POR2</td><td>PCR7[10-8]</td><td>PCR7[11]</td></tr> <tr> <td>POR3</td><td>PCR7[10-8]</td><td>PCR7[11]</td></tr> </tbody> </table><br><b>NOTE</b><br>The descriptions of the field settings vary by module instance.                                                                                                                                                                                                          | Instance               | Field supported in          | Field not supported in | POR1                                                                                                                                                                                             | PCR7 | — | POR2 | PCR7[10-8] | PCR7[11] | POR3 | PCR7[10-8] | PCR7[11] |
| Instance    | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Field not supported in |                             |                        |                                                                                                                                                                                                  |      |   |      |            |          |      |            |          |
| POR1        | PCR7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | —                      |                             |                        |                                                                                                                                                                                                  |      |   |      |            |          |      |            |          |
| POR2        | PCR7[10-8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | PCR7[11]               |                             |                        |                                                                                                                                                                                                  |      |   |      |            |          |      |            |          |
| POR3        | PCR7[10-8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | PCR7[11]               |                             |                        |                                                                                                                                                                                                  |      |   |      |            |          |      |            |          |
|             | <table border="1"> <thead> <tr> <th>Instance</th><th>Field value and description</th></tr> </thead> <tbody> <tr> <td>POR1</td><td>0000b - Alternative 0 (GPIO)<br/>0001b - Alternative 1 (chip-specific)<br/>0010b - Alternative 2 (chip-specific)<br/>0011b - Alternative 3 (chip-specific)<br/>0100b - Alternative 4 (chip-specific)</td></tr> </tbody> </table>                                                                                                                                                                                                                                                    | Instance               | Field value and description | POR1                   | 0000b - Alternative 0 (GPIO)<br>0001b - Alternative 1 (chip-specific)<br>0010b - Alternative 2 (chip-specific)<br>0011b - Alternative 3 (chip-specific)<br>0100b - Alternative 4 (chip-specific) |      |   |      |            |          |      |            |          |
| Instance    | Field value and description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                        |                             |                        |                                                                                                                                                                                                  |      |   |      |            |          |      |            |          |
| POR1        | 0000b - Alternative 0 (GPIO)<br>0001b - Alternative 1 (chip-specific)<br>0010b - Alternative 2 (chip-specific)<br>0011b - Alternative 3 (chip-specific)<br>0100b - Alternative 4 (chip-specific)                                                                                                                                                                                                                                                                                                                                                                                                                      |                        |                             |                        |                                                                                                                                                                                                  |      |   |      |            |          |      |            |          |

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                         |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | Instance                                                                                                                                                                   | Field value and description                                                                                                                                                                                                                                                                                                             |
|          |                                                                                                                                                                            | 0101b - Alternative 5 (chip-specific)<br>0110b - Alternative 6 (chip-specific)<br>0111b - Alternative 7 (chip-specific)<br>1000b - Alternative 8 (chip-specific)<br>1001b - Alternative 9 (chip-specific)<br>1010b - Alternative 10 (chip-specific)<br>1011b - Alternative 11 (chip-specific)<br>1100b - Alternative 12 (chip-specific) |
|          | PORTR2                                                                                                                                                                     | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific)                     |
|          | PORTR3                                                                                                                                                                     | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific)                     |
| 7<br>—   | Reserved                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                         |
| 6<br>DSE | Drive Strength Enable<br><br>Configures drive strength, low or high, on each pin.<br><br>The drive strength configuration is valid for all digital pin multiplexing modes. |                                                                                                                                                                                                                                                                                                                                         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | <ul style="list-style-type: none"> <li>When this field = 0, low drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> <li>When this field = 1, high drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul> 0b - Low<br>1b - High                                                                                                        |
| 5<br>ODE | Open Drain Enable<br>Enables open drain output on each pin.<br>The open drain configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, the open drain output is disabled on the corresponding pin.</li> <li>When this field = 1, the open drain output is enabled on the corresponding pin, if the pin is configured as a digital output.</li> </ul> 0b - Disables<br>1b - Enables |
| 4<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3<br>SRE | Slew Rate Enable<br>Configures the slew rate feature, fast or slow, on each corresponding pin.<br>The slew rate configuration is valid for all digital pin multiplexing modes.           0b - Fast<br>1b - Slow                                                                                                                                                                                                                                      |
| 2<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1<br>PE  | Pull Enable<br>Enables the internal pull resistor.<br>This configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, the internal pull resistor is not enabled on the corresponding pin.</li> <li>When this field = 1, the internal pull resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> 0b - Disables<br>1b - Enables        |
| 0<br>PS  | Pull Select<br>Enables the internal pullup or pulldown resistor.                                                                                                                                                                                                                                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pulldown resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> <li>When this field = 1, the internal pullup resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> </ul> <p>0b - Enables internal pulldown resistor<br/>1b - Enables internal pullup resistor</p> |

#### 11.6.1.14 Pin Control 8 (PCR8)

##### Offset

| Register | Offset |
|----------|--------|
| PCR8     | A0h    |

##### Function

Configures pin control features on each pin.

---

##### NOTE

Do not modify pin configuration registers associated with pins that are unavailable in your selected package. All unbonded pins unavailable in your package default to the Disabled state for lowest power consumption.

---

##### NOTE

Each module instance supports a different number of registers.

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| POR0     | —                  | PCR8                   |
| POR1     | PCR8               | —                      |
| POR2     | —                  | PCR8                   |
| POR3     | PCR8               | —                      |

**Diagram**

| Bits  | 31 | 30 | 29  | 28  | 27  | 26 | 25 | 24 | 23   | 22  | 21  | 20  | 19  | 18 | 17 | 16 |
|-------|----|----|-----|-----|-----|----|----|----|------|-----|-----|-----|-----|----|----|----|
| R     | 0  |    |     |     |     |    |    |    |      |     |     |     |     |    |    |    |
| W     |    |    |     |     |     |    |    |    |      |     |     |     |     |    |    |    |
| Reset | 0  | 0  | 0   | 0   | 0   | 0  | 0  | 0  | 0    | 0   | 0   | 0   | 0   | 0  | 0  | 0  |
| Bits  | 15 | 14 | 13  | 12  | 11  | 10 | 9  | 8  | 7    | 6   | 5   | 4   | 3   | 2  | 1  | 0  |
| R     | LK | 0  | INV | IBE | MUX |    |    |    | DSE1 | DSE | ODE | PFE | SRE | PV | PE | PS |
| W     |    |    |     |     |     |    |    |    |      |     |     |     |     |    |    |    |
| Reset | 0  | 0  | 0   | 0   | 0   | 0  | 0  | 0  | 0    | 0   | 0   | 0   | 0   | 0  | 0  | 0  |

**Fields**

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 15<br>LK    | <p>Lock Register</p> <p>Locks this PCR.</p> <p>When a PCR<math>n</math> is locked, its fields cannot be updated until the next reset.</p> <p>0b - Does not lock</p> <p>1b - Locks</p>                                                                                                                                                                                                              |
| 14<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 13<br>INV   | <p>Invert Input</p> <p>Inverts the digital input.</p> <p>0b - Does not invert</p> <p>1b - Inverts</p>                                                                                                                                                                                                                                                                                              |
| 12<br>IBE   | <p>Input Buffer Enable</p> <p>Enables digital input buffer. When disabled, the digital input is required for analog functions.</p> <p>0b - Disables</p> <p>1b - Enables</p>                                                                                                                                                                                                                        |
| 11-8<br>MUX | <p>Pin Multiplex Control</p> <p>Configures the multiplexing slots on each pin.</p> <p>Not all pins support all pin multiplexing slots. Unimplemented pin multiplexing slots are reserved.</p> <p>Unimplemented pin multiplexing slots can result in different behaviors, if the unimplemented slot is phantomed (because the module is phantomed on that die) versus unimplemented on the die.</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                        |                    |                        |       |      |   |       |   |      |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|-------|------|---|-------|---|------|
|           | <p>The corresponding pin is configured according to the following pin multiplexing slots:</p> <ul style="list-style-type: none"> <li>0000b - Alternative 0 (GPIO)</li> <li>0001b - Alternative 1 (chip-specific)</li> <li>0010b - Alternative 2 (chip-specific)</li> <li>0011b - Alternative 3 (chip-specific)</li> <li>0100b - Alternative 4 (chip-specific)</li> <li>0101b - Alternative 5 (chip-specific)</li> <li>0110b - Alternative 6 (chip-specific)</li> <li>0111b - Alternative 7 (chip-specific)</li> <li>1000b - Alternative 8 (chip-specific)</li> <li>1001b - Alternative 9 (chip-specific)</li> <li>1010b - Alternative 10 (chip-specific)</li> <li>1011b - Alternative 11 (chip-specific)</li> <li>1100b - Alternative 12 (chip-specific)</li> <li>1101b - Alternative 13 (chip-specific)</li> </ul>                                            |                        |                    |                        |       |      |   |       |   |      |
| 7<br>DSE1 | <p>Drive Strength Enable</p> <p>Configures the drive strength on each pin.</p> <p>The drive strength configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>• If this field = 0, normal drive strength is configured on the corresponding pin.</li> <li>• If this field = 1, double drive strength is configured on the corresponding pin.</li> </ul> <p><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> <table border="1" data-bbox="334 1446 1455 1626"> <thead> <tr> <th>Instance</th><th>Field supported in</th><th>Field not supported in</th></tr> </thead> <tbody> <tr> <td>PORT1</td><td>PCR8</td><td>—</td></tr> <tr> <td>PORT3</td><td>—</td><td>PCR8</td></tr> </tbody> </table> <p>0b - Normal<br/>1b - Double</p> | Instance               | Field supported in | Field not supported in | PORT1 | PCR8 | — | PORT3 | — | PCR8 |
| Instance  | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Field not supported in |                    |                        |       |      |   |       |   |      |
| PORT1     | PCR8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | —                      |                    |                        |       |      |   |       |   |      |
| PORT3     | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | PCR8                   |                    |                        |       |      |   |       |   |      |
| 6<br>DSE  | <p>Drive Strength Enable</p> <p>Configures drive strength, low or high, on each pin.</p> <p>The drive strength configuration is valid for all digital pin multiplexing modes.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |                    |                        |       |      |   |       |   |      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                        |                    |                        |       |      |   |       |   |      |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|-------|------|---|-------|---|------|
|          | <ul style="list-style-type: none"> <li>When this field = 0, low drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> <li>When this field = 1, high drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul> <p>0b - Low<br/>1b - High</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                        |                    |                        |       |      |   |       |   |      |
| 5<br>ODE | <p>Open Drain Enable</p> <p>Enables open drain output on each pin.</p> <p>The open drain configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the open drain output is disabled on the corresponding pin.</li> <li>When this field = 1, the open drain output is enabled on the corresponding pin, if the pin is configured as a digital output.</li> </ul> <p>0b - Disables<br/>1b - Enables</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                        |                    |                        |       |      |   |       |   |      |
| 4<br>PFE | <p>Passive Filter Enable</p> <p>Enables passive input filter on each pin.</p> <p>The passive filter configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the passive input filter is disabled on the corresponding pin.</li> <li>When this field = 1, the passive input filter is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> <p>See the chip's data sheet for filter characteristics.</p> <p><b>NOTE</b><br/>This field is not supported in every instance. The following table includes only supported registers.</p> <table border="1"> <thead> <tr> <th>Instance</th><th>Field supported in</th><th>Field not supported in</th></tr> </thead> <tbody> <tr> <td>PORT1</td><td>PCR8</td><td>—</td></tr> <tr> <td>PORT3</td><td>—</td><td>PCR8</td></tr> </tbody> </table> <p>0b - Disables<br/>1b - Enables</p> | Instance               | Field supported in | Field not supported in | PORT1 | PCR8 | — | PORT3 | — | PCR8 |
| Instance | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Field not supported in |                    |                        |       |      |   |       |   |      |
| PORT1    | PCR8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | —                      |                    |                        |       |      |   |       |   |      |
| PORT3    | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | PCR8                   |                    |                        |       |      |   |       |   |      |
| 3<br>SRE | <p>Slew Rate Enable</p> <p>Configures the slew rate feature, fast or slow, on each corresponding pin.</p> <p>The slew rate configuration is valid for all digital pin multiplexing modes.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                        |                    |                        |       |      |   |       |   |      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        |                    |                        |      |      |   |      |   |      |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|------|------|---|------|---|------|
|          | 0b - Fast<br>1b - Slow                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                        |                    |                        |      |      |   |      |   |      |
| 2<br>PV  | Pull Value<br>Selects high or low internal pull resistor value.<br>The pull value configuration is valid for all digital pin multiplexing modes. <p style="text-align: center;"><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> <table border="1" style="width: 100%; border-collapse: collapse;"> <thead> <tr> <th>Instance</th><th>Field supported in</th><th>Field not supported in</th></tr> </thead> <tbody> <tr> <td>POR1</td><td>PCR8</td><td>—</td></tr> <tr> <td>POR3</td><td>—</td><td>PCR8</td></tr> </tbody> </table><br>0b - Low<br>1b - High | Instance               | Field supported in | Field not supported in | POR1 | PCR8 | — | POR3 | — | PCR8 |
| Instance | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Field not supported in |                    |                        |      |      |   |      |   |      |
| POR1     | PCR8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | —                      |                    |                        |      |      |   |      |   |      |
| POR3     | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | PCR8                   |                    |                        |      |      |   |      |   |      |
| 1<br>PE  | Pull Enable<br>Enables the internal pull resistor.<br>This configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>• When this field = 0, the internal pull resistor is not enabled on the corresponding pin.</li> <li>• When this field = 1, the internal pull resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> 0b - Disables<br>1b - Enables                                                                                                                                                                                       |                        |                    |                        |      |      |   |      |   |      |
| 0<br>PS  | Pull Select<br>Enables the internal pullup or pulldown resistor.<br>This configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>• When this field = 0, the internal pulldown resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> <li>• When this field = 1, the internal pullup resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> </ul> 0b - Enables internal pulldown resistor<br>1b - Enables internal pullup resistor                                                       |                        |                    |                        |      |      |   |      |   |      |

### 11.6.1.15 Pin Control 9 (PCR9)

#### Offset

| Register | Offset |
|----------|--------|
| PCR9     | A4h    |

#### Function

Configures pin control features on each pin.

#### NOTE

Do not modify pin configuration registers associated with pins that are unavailable in your selected package. All unbonded pins unavailable in your package default to the Disabled state for lowest power consumption.

#### NOTE

Each module instance supports a different number of registers.

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| PORTE    | —                  | PCR9                   |
| PORTE    | PCR9               | —                      |
| PORTE    | —                  | PCR9                   |
| PORTE    | PCR9               | —                      |

#### Diagram



#### Fields

| Field | Function |
|-------|----------|
| 31-16 | Reserved |
| —     |          |

Table continues on the next page...

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>LK    | <p>Lock Register</p> <p>Locks this PCR.</p> <p>When a PCR<math>n</math> is locked, its fields cannot be updated until the next reset.</p> <p>0b - Does not lock</p> <p>1b - Locks</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 14<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 13<br>INV   | <p>Invert Input</p> <p>Inverts the digital input.</p> <p>0b - Does not invert</p> <p>1b - Inverts</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 12<br>IBE   | <p>Input Buffer Enable</p> <p>Enables digital input buffer. When disabled, the digital input is required for analog functions.</p> <p>0b - Disables</p> <p>1b - Enables</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 11-8<br>MUX | <p>Pin Multiplex Control</p> <p>Configures the multiplexing slots on each pin.</p> <p>Not all pins support all pin multiplexing slots. Unimplemented pin multiplexing slots are reserved.</p> <p>Unimplemented pin multiplexing slots can result in different behaviors, if the unimplemented slot is phantomed (because the module is phantomed on that die) versus unimplemented on the die.</p> <p>The corresponding pin is configured according to the following pin multiplexing slots:</p> <ul style="list-style-type: none"> <li>0000b - Alternative 0 (GPIO)</li> <li>0001b - Alternative 1 (chip-specific)</li> <li>0010b - Alternative 2 (chip-specific)</li> <li>0011b - Alternative 3 (chip-specific)</li> <li>0100b - Alternative 4 (chip-specific)</li> <li>0101b - Alternative 5 (chip-specific)</li> <li>0110b - Alternative 6 (chip-specific)</li> <li>0111b - Alternative 7 (chip-specific)</li> <li>1000b - Alternative 8 (chip-specific)</li> <li>1001b - Alternative 9 (chip-specific)</li> <li>1010b - Alternative 10 (chip-specific)</li> </ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                        |                    |                        |       |      |   |       |   |      |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|-------|------|---|-------|---|------|
|           | 1011b - Alternative 11 (chip-specific)<br>1100b - Alternative 12 (chip-specific)<br>1101b - Alternative 13 (chip-specific)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        |                    |                        |       |      |   |       |   |      |
| 7<br>DSE1 | Drive Strength Enable<br>Configures the drive strength on each pin.<br>The drive strength configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>• If this field = 0, normal drive strength is configured on the corresponding pin.</li> <li>• If this field = 1, double drive strength is configured on the corresponding pin.</li> </ul> <p><b>NOTE</b><br/>           This field is not supported in every instance. The following table includes only supported registers.</p> <table border="1" style="width: 100%; border-collapse: collapse;"> <thead> <tr> <th>Instance</th> <th>Field supported in</th> <th>Field not supported in</th> </tr> </thead> <tbody> <tr> <td>PORT1</td> <td>PCR9</td> <td>—</td> </tr> <tr> <td>PORT3</td> <td>—</td> <td>PCR9</td> </tr> </tbody> </table> 0b - Normal<br>1b - Double | Instance               | Field supported in | Field not supported in | PORT1 | PCR9 | — | PORT3 | — | PCR9 |
| Instance  | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Field not supported in |                    |                        |       |      |   |       |   |      |
| PORT1     | PCR9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | —                      |                    |                        |       |      |   |       |   |      |
| PORT3     | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | PCR9                   |                    |                        |       |      |   |       |   |      |
| 6<br>DSE  | Drive Strength Enable<br>Configures drive strength, low or high, on each pin.<br>The drive strength configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>• When this field = 0, low drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> <li>• When this field = 1, high drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul> 0b - Low<br>1b - High                                                                                                                                                                                                                                                                                                                                                      |                        |                    |                        |       |      |   |       |   |      |
| 5<br>ODE  | Open Drain Enable<br>Enables open drain output on each pin.<br>The open drain configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>• When this field = 0, the open drain output is disabled on the corresponding pin.</li> <li>• When this field = 1, the open drain output is enabled on the corresponding pin, if the pin is configured as a digital output.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        |                    |                        |       |      |   |       |   |      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                        |                    |                        |       |      |   |       |   |      |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|-------|------|---|-------|---|------|
|          | 0b - Disables<br>1b - Enables                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                        |                    |                        |       |      |   |       |   |      |
| 4<br>PFE | <b>Passive Filter Enable</b><br>Enables passive input filter on each pin.<br>The passive filter configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>• When this field = 0, the passive input filter is disabled on the corresponding pin.</li> <li>• When this field = 1, the passive input filter is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> See the chip's data sheet for filter characteristics. <p style="text-align: center;"><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> <table border="1" style="margin-left: auto; margin-right: auto;"> <thead> <tr> <th>Instance</th><th>Field supported in</th><th>Field not supported in</th></tr> </thead> <tbody> <tr> <td>PORT1</td><td>PCR9</td><td>—</td></tr> <tr> <td>PORT3</td><td>—</td><td>PCR9</td></tr> </tbody> </table> | Instance               | Field supported in | Field not supported in | PORT1 | PCR9 | — | PORT3 | — | PCR9 |
| Instance | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Field not supported in |                    |                        |       |      |   |       |   |      |
| PORT1    | PCR9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | —                      |                    |                        |       |      |   |       |   |      |
| PORT3    | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | PCR9                   |                    |                        |       |      |   |       |   |      |
|          | 0b - Disables<br>1b - Enables                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                        |                    |                        |       |      |   |       |   |      |
| 3<br>SRE | <b>Slew Rate Enable</b><br>Configures the slew rate feature, fast or slow, on each corresponding pin.<br>The slew rate configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>0b - Fast</li> <li>1b - Slow</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                        |                    |                        |       |      |   |       |   |      |
| 2<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                        |                    |                        |       |      |   |       |   |      |
| 1<br>PE  | <b>Pull Enable</b><br>Enables the internal pull resistor.<br>This configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>• When this field = 0, the internal pull resistor is not enabled on the corresponding pin.</li> <li>• When this field = 1, the internal pull resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                        |                    |                        |       |      |   |       |   |      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | 0b - Disables<br>1b - Enables                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0<br>PS | Pull Select<br>Enables the internal pullup or pulldown resistor.<br>This configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>• When this field = 0, the internal pulldown resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> <li>• When this field = 1, the internal pullup resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> </ul> 0b - Enables internal pulldown resistor<br>1b - Enables internal pullup resistor |

#### 11.6.1.16 Pin Control a (PCR10 - PCR13)

##### Offset

| Register | Offset |
|----------|--------|
| PCR10    | A8h    |
| PCR11    | ACh    |
| PCR12    | B0h    |
| PCR13    | B4h    |

##### Function

Configures pin control features on each pin.

##### NOTE

Do not modify pin configuration registers associated with pins that are unavailable in your selected package. All unbonded pins unavailable in your package default to the Disabled state for lowest power consumption.

##### NOTE

Each module instance supports a different number of registers.

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| PORT0    | —                  | PCR10–PCR13            |
| PORT1    | PCR10–PCR13        | —                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| PORT2    | PCR12–PCR13        | PCR10–PCR11            |
| PORT3    | PCR10–PCR13        | —                      |

## Diagram



Reset See [Register reset values](#).



---

Reset See [Register reset values](#).

## Register reset values

| Register    | Reset value                                                                                              |
|-------------|----------------------------------------------------------------------------------------------------------|
| PCR10–PCR11 | PORT0: Register not supported<br>PORT1: 0000_0000h<br>PORT2: Register not supported<br>PORT3: 0000_0000h |
| PCR12–PCR13 | PORT0: Register not supported<br>PORT1–PORT3: 0000_0000h                                                 |

## Fields

| Field      | Function                                                                                                                                             |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>— | Reserved                                                                                                                                             |
| 15<br>LK   | Lock Register<br>Locks this PCR.<br>When a PCR $n$ is locked, its fields cannot be updated until the next reset.<br>0b - Does not lock<br>1b - Locks |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| 14<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |
| 13<br>INV   | Invert Input<br><br>Inverts the digital input.<br><br>0b - Does not invert<br><br>1b - Inverts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                        |
| 12<br>IBE   | Input Buffer Enable<br><br>Enables digital input buffer. When disabled, the digital input is required for analog functions.<br><br>0b - Disables<br><br>1b - Enables                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                        |
| 11-8<br>MUX | Pin Multiplex Control<br><br>Configures the multiplexing slots on each pin.<br><br>Not all pins support all pin multiplexing slots. Unimplemented pin multiplexing slots are reserved.<br><br>Unimplemented pin multiplexing slots can result in different behaviors, if the unimplemented slot is phantomed (because the module is phantomed on that die) versus unimplemented on the die.<br><br>The corresponding pin is configured according to the following pin multiplexing slots:<br><br><b>NOTE</b><br>This field is not supported in every instance. The following table includes only supported registers. |                        |
| Instance    | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Field not supported in |
| POR1        | PCR10-PCR13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | —                      |
| POR2        | PCR12-PCR13[10-8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | PCR12-PCR13[11]        |
| POR3        | PCR10-PCR13                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | —                      |
|             | 000b - Alternative 0 (GPIO)<br>0000b - Alternative 0 (GPIO)<br>0001b - Alternative 1 (chip-specific)<br>001b - Alternative 1 (chip-specific)<br>0010b - Alternative 2 (chip-specific)<br>0011b - Alternative 3 (chip-specific)<br>010b - Alternative 2 (chip-specific)                                                                                                                                                                                                                                                                                                                                                |                        |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 0100b - Alternative 4 (chip-specific)<br>0101b - Alternative 5 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>0110b - Alternative 6 (chip-specific)<br>0111b - Alternative 7 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>1000b - Alternative 8 (chip-specific)<br>1001b - Alternative 9 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>1010b - Alternative 10 (chip-specific)<br>1011b - Alternative 11 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>1100b - Alternative 12 (chip-specific)<br>1101b - Alternative 13 (chip-specific)<br>111b - Alternative 7 (chip-specific) |
| 7<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6<br>DSE | <b>Drive Strength Enable</b><br>Configures drive strength, low or high, on each pin.<br>The drive strength configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, low drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> <li>When this field = 1, high drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul> 0b - Low<br>1b - High                                                                                                            |
| 5<br>ODE | <b>Open Drain Enable</b><br>Enables open drain output on each pin.<br>The open drain configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, the open drain output is disabled on the corresponding pin.</li> <li>When this field = 1, the open drain output is enabled on the corresponding pin, if the pin is configured as a digital output.</li> </ul> 0b - Disables                                                                                                                                                                                        |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 1b - Enables                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 4<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3<br>SRE | <p>Slew Rate Enable</p> <p>Configures the slew rate feature, fast or slow, on each corresponding pin.</p> <p>The slew rate configuration is valid for all digital pin multiplexing modes.</p> <p>0b - Fast</p> <p>1b - Slow</p>                                                                                                                                                                                                                                                                                                                                                                         |
| 2<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1<br>PE  | <p>Pull Enable</p> <p>Enables the internal pull resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pull resistor is not enabled on the corresponding pin.</li> <li>When this field = 1, the internal pull resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> <p>0b - Disables</p> <p>1b - Enables</p>                                                                                                                                 |
| 0<br>PS  | <p>Pull Select</p> <p>Enables the internal pullup or pulldown resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pulldown resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> <li>When this field = 1, the internal pullup resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> </ul> <p>0b - Enables internal pulldown resistor</p> <p>1b - Enables internal pullup resistor</p> |

### 11.6.1.17 Pin Control a (PCR14 - PCR15)

#### Offset

| Register | Offset |
|----------|--------|
| PCR14    | B8h    |
| PCR15    | BCh    |

#### Function

Configures pin control features on each pin.

**NOTE**

Do not modify pin configuration registers associated with pins that are unavailable in your selected package. All unbonded pins unavailable in your package default to the Disabled state for lowest power consumption.

**NOTE**

Each module instance supports a different number of registers.

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| PORTE    | —                  | PCR14–PCR15            |
| PORTF    | —                  | PCR14–PCR15            |
| PORTG    | —                  | PCR14–PCR15            |
| PORTH    | PCR14–PCR15        | —                      |

#### Diagram



#### Fields

| Field | Function |
|-------|----------|
| 31-16 | Reserved |

Table continues on the next page...

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15<br>LK    | <p>Lock Register</p> <p>Locks this PCR.</p> <p>When a PCR<math>n</math> is locked, its fields cannot be updated until the next reset.</p> <p>0b - Does not lock<br/>1b - Locks</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 14<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 13<br>INV   | <p>Invert Input</p> <p>Inverts the digital input.</p> <p>0b - Does not invert<br/>1b - Inverts</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 12<br>IBE   | <p>Input Buffer Enable</p> <p>Enables digital input buffer. When disabled, the digital input is required for analog functions.</p> <p>0b - Disables<br/>1b - Enables</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 11-8<br>MUX | <p>Pin Multiplex Control</p> <p>Configures the multiplexing slots on each pin.</p> <p>Not all pins support all pin multiplexing slots. Unimplemented pin multiplexing slots are reserved.</p> <p>Unimplemented pin multiplexing slots can result in different behaviors, if the unimplemented slot is phantomed (because the module is phantomed on that die) versus unimplemented on the die.</p> <p>The corresponding pin is configured according to the following pin multiplexing slots:</p> <ul style="list-style-type: none"> <li>0000b - Alternative 0 (GPIO)</li> <li>0001b - Alternative 1 (chip-specific)</li> <li>0010b - Alternative 2 (chip-specific)</li> <li>0011b - Alternative 3 (chip-specific)</li> <li>0100b - Alternative 4 (chip-specific)</li> <li>0101b - Alternative 5 (chip-specific)</li> <li>0110b - Alternative 6 (chip-specific)</li> <li>0111b - Alternative 7 (chip-specific)</li> <li>1000b - Alternative 8 (chip-specific)</li> <li>1001b - Alternative 9 (chip-specific)</li> </ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 1010b - Alternative 10 (chip-specific)<br>1011b - Alternative 11 (chip-specific)<br>1100b - Alternative 12 (chip-specific)<br>1101b - Alternative 13 (chip-specific)                                                                                                                                                                                                                                                                                                                                                    |
| 7<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6<br>DSE | <b>Drive Strength Enable</b><br>Configures drive strength, low or high, on each pin.<br>The drive strength configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, low drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> <li>When this field = 1, high drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul> 0b - Low<br>1b - High |
| 5<br>ODE | <b>Open Drain Enable</b><br>Enables open drain output on each pin.<br>The open drain configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, the open drain output is disabled on the corresponding pin.</li> <li>When this field = 1, the open drain output is enabled on the corresponding pin, if the pin is configured as a digital output.</li> </ul> 0b - Disables<br>1b - Enables                                                             |
| 4<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3<br>SRE | <b>Slew Rate Enable</b><br>Configures the slew rate feature, fast or slow, on each corresponding pin.<br>The slew rate configuration is valid for all digital pin multiplexing modes.           0b - Fast<br>1b - Slow                                                                                                                                                                                                                                                                                                  |
| 2<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>PE | <p>Pull Enable</p> <p>Enables the internal pull resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pull resistor is not enabled on the corresponding pin.</li> <li>When this field = 1, the internal pull resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> <p>0b - Disables<br/>1b - Enables</p>                                                                                                                                 |
| 0<br>PS | <p>Pull Select</p> <p>Enables the internal pullup or pulldown resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pulldown resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> <li>When this field = 1, the internal pullup resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> </ul> <p>0b - Enables internal pulldown resistor<br/>1b - Enables internal pullup resistor</p> |

### 11.6.1.18 Pin Control 16 (PCR16)

#### Offset

| Register | Offset |
|----------|--------|
| PCR16    | C0h    |

#### Function

Configures pin control features on each pin.

#### NOTE

Do not modify pin configuration registers associated with pins that are unavailable in your selected package. All unbonded pins unavailable in your package default to the Disabled state for lowest power consumption.

#### NOTE

Each module instance supports a different number of registers.

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| PORT0    | PCR16              | —                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| POR1     | —                  | PCR16                  |
| POR2     | PCR16              | —                      |
| POR3     | —                  | PCR16                  |

### Diagram



### Fields

| Field      | Function                                                                                                                                             |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>— | Reserved                                                                                                                                             |
| 15<br>LK   | Lock Register<br>Locks this PCR.<br>When a PCR $n$ is locked, its fields cannot be updated until the next reset.<br>0b - Does not lock<br>1b - Locks |
| 14<br>—    | Reserved                                                                                                                                             |
| 13<br>INV  | Invert Input<br>Inverts the digital input.<br>0b - Does not invert<br>1b - Inverts                                                                   |
| 12         | Input Buffer Enable                                                                                                                                  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                        |                             |                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |   |       |             |           |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-----------------------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---|-------|-------------|-----------|
| IBE         | Enables digital input buffer. When disabled, the digital input is required for analog functions.<br>0b - Disables<br>1b - Enables                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                        |                             |                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |   |       |             |           |
| 11-8<br>MUX | Pin Multiplex Control<br><br>Configures the multiplexing slots on each pin.<br><br>Not all pins support all pin multiplexing slots. Unimplemented pin multiplexing slots are reserved.<br><br>Unimplemented pin multiplexing slots can result in different behaviors, if the unimplemented slot is phantomed (because the module is phantomed on that die) versus unimplemented on the die.<br><br>The corresponding pin is configured according to the following pin multiplexing slots:<br><br><b>NOTE</b><br>This field is not supported in every instance. The following table includes only supported registers.                                                                                                                                                                                                    |                        |                             |                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |   |       |             |           |
|             | <table border="1"> <thead> <tr> <th>Instance</th><th>Field supported in</th><th>Field not supported in</th></tr> </thead> <tbody> <tr> <td>PORT0</td><td>PCR16</td><td>—</td></tr> <tr> <td>PORT2</td><td>PCR16[10–8]</td><td>PCR16[11]</td></tr> </tbody> </table><br><b>NOTE</b><br>The descriptions of the field settings vary by module instance.                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Instance               | Field supported in          | Field not supported in | PORT0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | PCR16 | — | PORT2 | PCR16[10–8] | PCR16[11] |
| Instance    | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Field not supported in |                             |                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |   |       |             |           |
| PORT0       | PCR16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | —                      |                             |                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |   |       |             |           |
| PORT2       | PCR16[10–8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | PCR16[11]              |                             |                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |   |       |             |           |
|             | <table border="1"> <thead> <tr> <th>Instance</th><th>Field value and description</th></tr> </thead> <tbody> <tr> <td>PORT0</td><td>           0000b - Alternative 0 (GPIO)<br/>           0001b - Alternative 1 (chip-specific)<br/>           0010b - Alternative 2 (chip-specific)<br/>           0011b - Alternative 3 (chip-specific)<br/>           0100b - Alternative 4 (chip-specific)<br/>           0101b - Alternative 5 (chip-specific)<br/>           0110b - Alternative 6 (chip-specific)<br/>           0111b - Alternative 7 (chip-specific)<br/>           1000b - Alternative 8 (chip-specific)<br/>           1001b - Alternative 9 (chip-specific)<br/>           1010b - Alternative 10 (chip-specific)<br/>           1011b - Alternative 11 (chip-specific)         </td></tr> </tbody> </table> | Instance               | Field value and description | PORT0                  | 0000b - Alternative 0 (GPIO)<br>0001b - Alternative 1 (chip-specific)<br>0010b - Alternative 2 (chip-specific)<br>0011b - Alternative 3 (chip-specific)<br>0100b - Alternative 4 (chip-specific)<br>0101b - Alternative 5 (chip-specific)<br>0110b - Alternative 6 (chip-specific)<br>0111b - Alternative 7 (chip-specific)<br>1000b - Alternative 8 (chip-specific)<br>1001b - Alternative 9 (chip-specific)<br>1010b - Alternative 10 (chip-specific)<br>1011b - Alternative 11 (chip-specific) |       |   |       |             |           |
| Instance    | Field value and description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |                             |                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |   |       |             |           |
| PORT0       | 0000b - Alternative 0 (GPIO)<br>0001b - Alternative 1 (chip-specific)<br>0010b - Alternative 2 (chip-specific)<br>0011b - Alternative 3 (chip-specific)<br>0100b - Alternative 4 (chip-specific)<br>0101b - Alternative 5 (chip-specific)<br>0110b - Alternative 6 (chip-specific)<br>0111b - Alternative 7 (chip-specific)<br>1000b - Alternative 8 (chip-specific)<br>1001b - Alternative 9 (chip-specific)<br>1010b - Alternative 10 (chip-specific)<br>1011b - Alternative 11 (chip-specific)                                                                                                                                                                                                                                                                                                                        |                        |                             |                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |   |       |             |           |

*Table continued from the previous page...*

| Field    | Function                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          |                    |                        |      |       |   |      |   |       |
|----------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--------------------|------------------------|------|-------|---|------|---|-------|
|          | Instance                               | Field value and description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |                    |                        |      |       |   |      |   |       |
|          | 1100b - Alternative 12 (chip-specific) |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |          |                    |                        |      |       |   |      |   |       |
|          | POR2                                   | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |          |                    |                        |      |       |   |      |   |       |
| 7        | DSE1                                   | <p>Drive Strength Enable</p> <p>Configures the drive strength on each pin.</p> <p>The drive strength configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>If this field = 0, normal drive strength is configured on the corresponding pin.</li> <li>If this field = 1, double drive strength is configured on the corresponding pin.</li> </ul> <p><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> <table border="1"> <thead> <tr> <th>Instance</th> <th>Field supported in</th> <th>Field not supported in</th> </tr> </thead> <tbody> <tr> <td>POR0</td> <td>PCR16</td> <td>—</td> </tr> <tr> <td>POR2</td> <td>—</td> <td>PCR16</td> </tr> </tbody> </table> <p>0b - Normal<br/>1b - Double</p> | Instance | Field supported in | Field not supported in | POR0 | PCR16 | — | POR2 | — | PCR16 |
| Instance | Field supported in                     | Field not supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          |                    |                        |      |       |   |      |   |       |
| POR0     | PCR16                                  | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |          |                    |                        |      |       |   |      |   |       |
| POR2     | —                                      | PCR16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |          |                    |                        |      |       |   |      |   |       |
| 6        | DSE                                    | <p>Drive Strength Enable</p> <p>Configures drive strength, low or high, on each pin.</p> <p>The drive strength configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, low drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> <li>When this field = 1, high drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul>                                                                                                                                                                                                                                                                                                                            |          |                    |                        |      |       |   |      |   |       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                        |                    |                        |       |       |   |       |   |       |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|-------|-------|---|-------|---|-------|
|          | <p>0b - Low<br/>1b - High</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                        |                    |                        |       |       |   |       |   |       |
| 5<br>ODE | <p>Open Drain Enable<br/>Enables open drain output on each pin.<br/>The open drain configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the open drain output is disabled on the corresponding pin.</li> <li>When this field = 1, the open drain output is enabled on the corresponding pin, if the pin is configured as a digital output.</li> </ul> <p>0b - Disables<br/>1b - Enables</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                        |                    |                        |       |       |   |       |   |       |
| 4<br>PFE | <p>Passive Filter Enable<br/>Enables passive input filter on each pin.<br/>The passive filter configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the passive input filter is disabled on the corresponding pin.</li> <li>When this field = 1, the passive input filter is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> <p>See the chip's data sheet for filter characteristics.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> <table border="1" style="margin-left: auto; margin-right: auto;"> <thead> <tr> <th>Instance</th><th>Field supported in</th><th>Field not supported in</th></tr> </thead> <tbody> <tr> <td>PORT0</td><td>PCR16</td><td>—</td></tr> <tr> <td>PORT2</td><td>—</td><td>PCR16</td></tr> </tbody> </table> <p>0b - Disables<br/>1b - Enables</p> | Instance               | Field supported in | Field not supported in | PORT0 | PCR16 | — | PORT2 | — | PCR16 |
| Instance | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Field not supported in |                    |                        |       |       |   |       |   |       |
| PORT0    | PCR16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | —                      |                    |                        |       |       |   |       |   |       |
| PORT2    | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | PCR16                  |                    |                        |       |       |   |       |   |       |
| 3<br>SRE | <p>Slew Rate Enable<br/>Configures the slew rate feature, fast or slow, on each corresponding pin.<br/>The slew rate configuration is valid for all digital pin multiplexing modes.</p> <p>0b - Fast<br/>1b - Slow</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |                    |                        |       |       |   |       |   |       |
| 2        | Pull Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                        |                    |                        |       |       |   |       |   |       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                        |                    |                        |       |       |   |       |   |       |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|-------|-------|---|-------|---|-------|
| PV       | <p>Selects high or low internal pull resistor value.</p> <p>The pull value configuration is valid for all digital pin multiplexing modes.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> <table border="1" style="width: 100%; border-collapse: collapse;"> <thead> <tr> <th>Instance</th><th>Field supported in</th><th>Field not supported in</th></tr> </thead> <tbody> <tr> <td>PORT0</td><td>PCR16</td><td>—</td></tr> <tr> <td>PORT2</td><td>—</td><td>PCR16</td></tr> </tbody> </table> <p style="margin-left: 40px;">0b - Low<br/>1b - High</p> | Instance               | Field supported in | Field not supported in | PORT0 | PCR16 | — | PORT2 | — | PCR16 |
| Instance | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Field not supported in |                    |                        |       |       |   |       |   |       |
| PORT0    | PCR16                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | —                      |                    |                        |       |       |   |       |   |       |
| PORT2    | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | PCR16                  |                    |                        |       |       |   |       |   |       |
| 1<br>PE  | <p>Pull Enable</p> <p>Enables the internal pull resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pull resistor is not enabled on the corresponding pin.</li> <li>When this field = 1, the internal pull resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> <p style="margin-left: 40px;">0b - Disables<br/>1b - Enables</p>                                                                                                                                                                          |                        |                    |                        |       |       |   |       |   |       |
| 0<br>PS  | <p>Pull Select</p> <p>Enables the internal pullup or pulldown resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pulldown resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> <li>When this field = 1, the internal pullup resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> </ul> <p style="margin-left: 40px;">0b - Enables internal pulldown resistor<br/>1b - Enables internal pullup resistor</p>                                          |                        |                    |                        |       |       |   |       |   |       |

### 11.6.1.19 Pin Control 17 (PCR17)

#### Offset

| Register | Offset |
|----------|--------|
| PCR17    | C4h    |

#### Function

Configures pin control features on each pin.

#### NOTE

Do not modify pin configuration registers associated with pins that are unavailable in your selected package. All unbonded pins unavailable in your package default to the Disabled state for lowest power consumption.

#### NOTE

Each module instance supports a different number of registers.

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| PORT0    | PCR17              | —                      |
| PORT1    | —                  | PCR17                  |
| PORT2    | PCR17              | —                      |
| PORT3    | —                  | PCR17                  |

#### Diagram



#### Fields

| Field | Function |
|-------|----------|
| 31-16 | Reserved |
| —     |          |

Table continues on the next page...

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |                    |                        |       |       |   |       |             |           |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|-------|-------|---|-------|-------------|-----------|
| 15<br>LK    | Lock Register<br>Locks this PCR.<br>When a PCR $n$ is locked, its fields cannot be updated until the next reset.<br>0b - Does not lock<br>1b - Locks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                        |                    |                        |       |       |   |       |             |           |
| 14<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |                    |                        |       |       |   |       |             |           |
| 13<br>INV   | Invert Input<br>Inverts the digital input.<br>0b - Does not invert<br>1b - Inverts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                        |                    |                        |       |       |   |       |             |           |
| 12<br>IBE   | Input Buffer Enable<br>Enables digital input buffer. When disabled, the digital input is required for analog functions.<br>0b - Disables<br>1b - Enables                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |                    |                        |       |       |   |       |             |           |
| 11-8<br>MUX | Pin Multiplex Control<br>Configures the multiplexing slots on each pin.<br>Not all pins support all pin multiplexing slots. Unimplemented pin multiplexing slots are reserved.<br>Unimplemented pin multiplexing slots can result in different behaviors, if the unimplemented slot is phantomed (because the module is phantomed on that die) versus unimplemented on the die.<br>The corresponding pin is configured according to the following pin multiplexing slots:<br><div style="text-align: center;"> <b>NOTE</b><br/>           This field is not supported in every instance. The following table includes only supported registers.         </div> <table border="1" style="width: 100%; border-collapse: collapse; margin-top: 10px;"> <thead> <tr> <th style="text-align: center;">Instance</th> <th style="text-align: center;">Field supported in</th> <th style="text-align: center;">Field not supported in</th> </tr> </thead> <tbody> <tr> <td style="text-align: center;">PORT0</td> <td style="text-align: center;">PCR17</td> <td style="text-align: center;">—</td> </tr> <tr> <td style="text-align: center;">PORT2</td> <td style="text-align: center;">PCR17[10-8]</td> <td style="text-align: center;">PCR17[11]</td> </tr> </tbody> </table> <div style="text-align: center;"> <b>NOTE</b><br/>           The descriptions of the field settings vary by module instance.         </div> | Instance               | Field supported in | Field not supported in | PORT0 | PCR17 | — | PORT2 | PCR17[10-8] | PCR17[11] |
| Instance    | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Field not supported in |                    |                        |       |       |   |       |             |           |
| PORT0       | PCR17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | —                      |                    |                        |       |       |   |       |             |           |
| PORT2       | PCR17[10-8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | PCR17[11]              |                    |                        |       |       |   |       |             |           |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Instance                                                                                                                                                                                                                                                                                                                                                                 | Field value and description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       | PORT0                                                                                                                                                                                                                                                                                                                                                                    | 0000b - Alternative 0 (GPIO)<br>0001b - Alternative 1 (chip-specific)<br>0010b - Alternative 2 (chip-specific)<br>0011b - Alternative 3 (chip-specific)<br>0100b - Alternative 4 (chip-specific)<br>0101b - Alternative 5 (chip-specific)<br>0110b - Alternative 6 (chip-specific)<br>0111b - Alternative 7 (chip-specific)<br>1000b - Alternative 8 (chip-specific)<br>1001b - Alternative 9 (chip-specific)<br>1010b - Alternative 10 (chip-specific)<br>1011b - Alternative 11 (chip-specific)<br>1100b - Alternative 12 (chip-specific) |
|       | PORT2                                                                                                                                                                                                                                                                                                                                                                    | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific)                                                                                                                                                                                                                         |
| 7     | <b>DSE1</b><br>Drive Strength Enable<br>Configures the drive strength on each pin.<br>The drive strength configuration is valid for all digital pin multiplexing modes.                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       | <ul style="list-style-type: none"> <li>• If this field = 0, normal drive strength is configured on the corresponding pin.</li> <li>• If this field = 1, double drive strength is configured on the corresponding pin.</li> </ul> <p><b>NOTE</b><br/>           This field is not supported in every instance. The following table includes only supported registers.</p> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                                                                                                                | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                    |                        |
|----------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------------------|
|                                                                                                                      | Instance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Field supported in | Field not supported in |
| PORT0                                                                                                                | PCR17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | —                  |                        |
| PORT2                                                                                                                | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | PCR17              |                        |
|                                                                                                                      | 0b - Normal<br>1b - Double                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                    |                        |
| 6<br>DSE                                                                                                             | <b>Drive Strength Enable</b><br>Configures drive strength, low or high, on each pin.<br>The drive strength configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, low drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> <li>When this field = 1, high drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul> 0b - Low<br>1b - High |                    |                        |
| 5<br>ODE                                                                                                             | <b>Open Drain Enable</b><br>Enables open drain output on each pin.<br>The open drain configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, the open drain output is disabled on the corresponding pin.</li> <li>When this field = 1, the open drain output is enabled on the corresponding pin, if the pin is configured as a digital output.</li> </ul> 0b - Disables<br>1b - Enables                                                             |                    |                        |
| 4<br>PFE                                                                                                             | <b>Passive Filter Enable</b><br>Enables passive input filter on each pin.<br>The passive filter configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, the passive input filter is disabled on the corresponding pin.</li> <li>When this field = 1, the passive input filter is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> See the chip's data sheet for filter characteristics.                     |                    |                        |
| <b>NOTE</b><br>This field is not supported in every instance. The following table includes only supported registers. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                    |                        |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                    |                        |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------------------|
|          | Instance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Field supported in | Field not supported in |
| PORT0    | PCR17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | —                  |                        |
| PORT2    | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | PCR17              |                        |
|          | 0b - Disables<br>1b - Enables                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                    |                        |
| 3<br>SRE | <b>Slew Rate Enable</b><br>Configures the slew rate feature, fast or slow, on each corresponding pin.<br>The slew rate configuration is valid for all digital pin multiplexing modes.<br>0b - Fast<br>1b - Slow                                                                                                                                                                                                                                                                                                                                                                          |                    |                        |
| 2<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                    |                        |
| 1<br>PE  | <b>Pull Enable</b><br>Enables the internal pull resistor.<br>This configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>• When this field = 0, the internal pull resistor is not enabled on the corresponding pin.</li> <li>• When this field = 1, the internal pull resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> 0b - Disables<br>1b - Enables                                                                                                                                 |                    |                        |
| 0<br>PS  | <b>Pull Select</b><br>Enables the internal pullup or pulldown resistor.<br>This configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>• When this field = 0, the internal pulldown resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> <li>• When this field = 1, the internal pullup resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> </ul> 0b - Enables internal pulldown resistor<br>1b - Enables internal pullup resistor |                    |                        |

### 11.6.1.20 Pin Control a (PCR20 - PCR21)

#### Offset

| Register | Offset |
|----------|--------|
| PCR20    | D0h    |
| PCR21    | D4h    |

#### Function

Configures pin control features on each pin.

**NOTE**

Do not modify pin configuration registers associated with pins that are unavailable in your selected package. All unbonded pins unavailable in your package default to the Disabled state for lowest power consumption.

**NOTE**

Each module instance supports a different number of registers.

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| PORTE    | —                  | PCR20–PCR21            |
| PORTF    | —                  | PCR20–PCR21            |
| PORTG    | PCR20–PCR21        | —                      |
| PORTH    | —                  | PCR20–PCR21            |

#### Diagram



#### Fields

| Field | Function |
|-------|----------|
| 31-16 | Reserved |

Table continues on the next page...

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 15<br>LK    | <p>Lock Register</p> <p>Locks this PCR.</p> <p>When a PCR<math>n</math> is locked, its fields cannot be updated until the next reset.</p> <p>0b - Does not lock<br/>1b - Locks</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 14<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 13<br>INV   | <p>Invert Input</p> <p>Inverts the digital input.</p> <p>0b - Does not invert<br/>1b - Inverts</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 12<br>IBE   | <p>Input Buffer Enable</p> <p>Enables digital input buffer. When disabled, the digital input is required for analog functions.</p> <p>0b - Disables<br/>1b - Enables</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 10-8<br>MUX | <p>Pin Multiplex Control</p> <p>Configures the multiplexing slots on each pin.</p> <p>Not all pins support all pin multiplexing slots. Unimplemented pin multiplexing slots are reserved.</p> <p>Unimplemented pin multiplexing slots can result in different behaviors, if the unimplemented slot is phantomed (because the module is phantomed on that die) versus unimplemented on the die.</p> <p>The corresponding pin is configured according to the following pin multiplexing slots:</p> <ul style="list-style-type: none"> <li>000b - Alternative 0 (GPIO)</li> <li>001b - Alternative 1 (chip-specific)</li> <li>010b - Alternative 2 (chip-specific)</li> <li>011b - Alternative 3 (chip-specific)</li> <li>100b - Alternative 4 (chip-specific)</li> <li>101b - Alternative 5 (chip-specific)</li> <li>110b - Alternative 6 (chip-specific)</li> <li>111b - Alternative 7 (chip-specific)</li> </ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6<br>DSE | <p>Drive Strength Enable</p> <p>Configures drive strength, low or high, on each pin.</p> <p>The drive strength configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, low drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> <li>When this field = 1, high drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul> <p>0b - Low<br/>1b - High</p> |
| 5<br>ODE | <p>Open Drain Enable</p> <p>Enables open drain output on each pin.</p> <p>The open drain configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the open drain output is disabled on the corresponding pin.</li> <li>When this field = 1, the open drain output is enabled on the corresponding pin, if the pin is configured as a digital output.</li> </ul> <p>0b - Disables<br/>1b - Enables</p>                                                             |
| 4<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3<br>SRE | <p>Slew Rate Enable</p> <p>Configures the slew rate feature, fast or slow, on each corresponding pin.</p> <p>The slew rate configuration is valid for all digital pin multiplexing modes.</p> <p>0b - Fast<br/>1b - Slow</p>                                                                                                                                                                                                                                                                                                            |
| 2<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1<br>PE  | <p>Pull Enable</p> <p>Enables the internal pull resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pull resistor is not enabled on the corresponding pin.</li> </ul>                                                                                                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | <ul style="list-style-type: none"> <li>When this field = 1, the internal pull resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> <p>0b - Disables<br/>1b - Enables</p>                                                                                                                                                                                                                                                                                                                                                                            |
| 0<br>PS | <p>Pull Select</p> <p>Enables the internal pullup or pulldown resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pulldown resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> <li>When this field = 1, the internal pullup resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> </ul> <p>0b - Enables internal pulldown resistor<br/>1b - Enables internal pullup resistor</p> |

#### 11.6.1.21 Pin Control a (PCR27 - PCR28)

##### Offset

| Register | Offset |
|----------|--------|
| PCR27    | ECh    |
| PCR28    | F0h    |

##### Function

Configures pin control features on each pin.

**NOTE**

Do not modify pin configuration registers associated with pins that are unavailable in your selected package. All unbonded pins unavailable in your package default to the Disabled state for lowest power consumption.

**NOTE**

Each module instance supports a different number of registers.

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| PORTE    | —                  | PCR27–PCR28            |
| PORTE    | —                  | PCR27–PCR28            |
| PORTE    | —                  | PCR27–PCR28            |

*Table continues on the next page...*

*Table continued from the previous page...*

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| POR3     | PCR27–PCR28        | —                      |

### Diagram



### Fields

| Field      | Function                                                                                                                                                         |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>— | Reserved                                                                                                                                                         |
| 15<br>LK   | Lock Register<br>Locks this PCR.<br><br>When a PCR $n$ is locked, its fields cannot be updated until the next reset.<br><br>0b - Does not lock<br>1b - Locks     |
| 14<br>—    | Reserved                                                                                                                                                         |
| 13<br>INV  | Invert Input<br><br>Inverts the digital input.<br><br>0b - Does not invert<br>1b - Inverts                                                                       |
| 12<br>IBE  | Input Buffer Enable<br><br>Enables digital input buffer. When disabled, the digital input is required for analog functions.<br><br>0b - Disables<br>1b - Enables |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 10-8<br>MUX | <p>Pin Multiplex Control</p> <p>Configures the multiplexing slots on each pin.</p> <p>Not all pins support all pin multiplexing slots. Unimplemented pin multiplexing slots are reserved.</p> <p>Unimplemented pin multiplexing slots can result in different behaviors, if the unimplemented slot is phantomed (because the module is phantomed on that die) versus unimplemented on the die.</p> <p>The corresponding pin is configured according to the following pin multiplexing slots:</p> <ul style="list-style-type: none"> <li>000b - Alternative 0 (GPIO)</li> <li>001b - Alternative 1 (chip-specific)</li> <li>010b - Alternative 2 (chip-specific)</li> <li>011b - Alternative 3 (chip-specific)</li> <li>100b - Alternative 4 (chip-specific)</li> <li>101b - Alternative 5 (chip-specific)</li> <li>110b - Alternative 6 (chip-specific)</li> <li>111b - Alternative 7 (chip-specific)</li> </ul> |
| 7<br>DSE1   | <p>Drive Strength Enable</p> <p>Configures the drive strength on each pin.</p> <p>The drive strength configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>• If this field = 0, normal drive strength is configured on the corresponding pin.</li> <li>• If this field = 1, double drive strength is configured on the corresponding pin.</li> </ul> <ul style="list-style-type: none"> <li>0b - Normal</li> <li>1b - Double</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 6<br>DSE    | <p>Drive Strength Enable</p> <p>Configures drive strength, low or high, on each pin.</p> <p>The drive strength configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>• When this field = 0, low drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> <li>• When this field = 1, high drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul> <ul style="list-style-type: none"> <li>0b - Low</li> <li>1b - High</li> </ul>                                                                                                                                                                                                                                                                                                                      |
| 5           | Open Drain Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ODE      | <p>Enables open drain output on each pin.</p> <p>The open drain configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the open drain output is disabled on the corresponding pin.</li> <li>When this field = 1, the open drain output is enabled on the corresponding pin, if the pin is configured as a digital output.</li> </ul> <p>0b - Disables<br/>1b - Enables</p>                                                                                                                                                   |
| 4<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3<br>SRE | <p>Slew Rate Enable</p> <p>Configures the slew rate feature, fast or slow, on each corresponding pin.</p> <p>The slew rate configuration is valid for all digital pin multiplexing modes.</p> <p>0b - Fast<br/>1b - Slow</p>                                                                                                                                                                                                                                                                                                                                                                         |
| 2<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 1<br>PE  | <p>Pull Enable</p> <p>Enables the internal pull resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pull resistor is not enabled on the corresponding pin.</li> <li>When this field = 1, the internal pull resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> <p>0b - Disables<br/>1b - Enables</p>                                                                                                                                 |
| 0<br>PS  | <p>Pull Select</p> <p>Enables the internal pullup or pulldown resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pulldown resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> <li>When this field = 1, the internal pullup resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> </ul> <p>0b - Enables internal pulldown resistor<br/>1b - Enables internal pullup resistor</p> |

### 11.6.1.22 Pin Control 29 (PCR29)

## Offset

| Register | Offset |
|----------|--------|
| PCR29    | F4h    |

## Function

Configures pin control features on each pin.

## **NOTE**

Do not modify pin configuration registers associated with pins that are unavailable in your selected package. All unbonded pins unavailable in your package default to the Disabled state for lowest power consumption.

## NOTE

**NOTE**  
Each module instance supports a different number of registers.

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| PORT0    | —                  | PCR29                  |
| PORT1    | PCR29              | —                      |
| PORT2    | —                  | PCR29                  |
| PORT3    | PCR29              | —                      |

## Diagram



**Reset** See [Register reset values](#)



[Reset](#) See [Register reset values](#)

### Register reset values

| Register | Reset value                                        |
|----------|----------------------------------------------------|
| PCR29    | PORT0: Register not supported<br>PORT1: 0000_0133h |

*Table continues on the next page...*

| Register | Reset value                                      |
|----------|--------------------------------------------------|
|          | POR2: Register not supported<br>POR3: 0000_1103h |

**Fields**

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 15<br>LK    | <p>Lock Register</p> <p>Locks this PCR.</p> <p>When a PCR<math>n</math> is locked, its fields cannot be updated until the next reset.</p> <p>0b - Does not lock</p> <p>1b - Locks</p>                                                                                                                                                                                                                                                                                                            |
| 14<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 13<br>INV   | <p>Invert Input</p> <p>Inverts the digital input.</p> <p>0b - Does not invert</p> <p>1b - Inverts</p>                                                                                                                                                                                                                                                                                                                                                                                            |
| 12<br>IBE   | <p>Input Buffer Enable</p> <p>Enables digital input buffer. When disabled, the digital input is required for analog functions.</p> <p>0b - Disables</p> <p>1b - Enables</p>                                                                                                                                                                                                                                                                                                                      |
| 11<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 10-8<br>MUX | <p>Pin Multiplex Control</p> <p>Configures the multiplexing slots on each pin.</p> <p>Not all pins support all pin multiplexing slots. Unimplemented pin multiplexing slots are reserved.</p> <p>Unimplemented pin multiplexing slots can result in different behaviors, if the unimplemented slot is phantomed (because the module is phantomed on that die) versus unimplemented on the die.</p> <p>The corresponding pin is configured according to the following pin multiplexing slots:</p> |

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                        |                             |                        |                                                                                                                                                 |            |                                                                                                                                                                                                                                                                                                                     |      |       |   |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|-----------------------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------|---|
|          | <p style="text-align: center;"><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                        |                             |                        |                                                                                                                                                 |            |                                                                                                                                                                                                                                                                                                                     |      |       |   |
|          | <table border="1"> <thead> <tr> <th>Instance</th><th>Field supported in</th><th>Field not supported in</th></tr> </thead> <tbody> <tr> <td>POR1</td><td>PCR29[9–8]</td><td>PCR29[10]</td></tr> <tr> <td>POR3</td><td>PCR29</td><td>—</td></tr> </tbody> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Instance               | Field supported in          | Field not supported in | POR1                                                                                                                                            | PCR29[9–8] | PCR29[10]                                                                                                                                                                                                                                                                                                           | POR3 | PCR29 | — |
| Instance | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Field not supported in |                             |                        |                                                                                                                                                 |            |                                                                                                                                                                                                                                                                                                                     |      |       |   |
| POR1     | PCR29[9–8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | PCR29[10]              |                             |                        |                                                                                                                                                 |            |                                                                                                                                                                                                                                                                                                                     |      |       |   |
| POR3     | PCR29                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | —                      |                             |                        |                                                                                                                                                 |            |                                                                                                                                                                                                                                                                                                                     |      |       |   |
|          | <p style="text-align: center;"><b>NOTE</b></p> <p>The descriptions of the field settings vary by module instance.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                        |                             |                        |                                                                                                                                                 |            |                                                                                                                                                                                                                                                                                                                     |      |       |   |
|          | <table border="1"> <thead> <tr> <th>Instance</th><th>Field value and description</th></tr> </thead> <tbody> <tr> <td>POR1</td><td>           00b - Alternative 0 (GPIO)<br/>           01b - Alternative 1 (chip-specific)<br/>           10b - Alternative 2 (chip-specific)<br/>           11b - Alternative 3 (chip-specific)         </td></tr> <tr> <td>POR3</td><td>           000b - Alternative 0 (GPIO)<br/>           001b - Alternative 1 (chip-specific)<br/>           010b - Alternative 2 (chip-specific)<br/>           011b - Alternative 3 (chip-specific)<br/>           100b - Alternative 4 (chip-specific)<br/>           101b - Alternative 5 (chip-specific)<br/>           110b - Alternative 6 (chip-specific)<br/>           111b - Alternative 7 (chip-specific)         </td></tr> </tbody> </table> | Instance               | Field value and description | POR1                   | 00b - Alternative 0 (GPIO)<br>01b - Alternative 1 (chip-specific)<br>10b - Alternative 2 (chip-specific)<br>11b - Alternative 3 (chip-specific) | POR3       | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific) |      |       |   |
| Instance | Field value and description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                        |                             |                        |                                                                                                                                                 |            |                                                                                                                                                                                                                                                                                                                     |      |       |   |
| POR1     | 00b - Alternative 0 (GPIO)<br>01b - Alternative 1 (chip-specific)<br>10b - Alternative 2 (chip-specific)<br>11b - Alternative 3 (chip-specific)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                        |                             |                        |                                                                                                                                                 |            |                                                                                                                                                                                                                                                                                                                     |      |       |   |
| POR3     | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                        |                             |                        |                                                                                                                                                 |            |                                                                                                                                                                                                                                                                                                                     |      |       |   |
| 7<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                        |                             |                        |                                                                                                                                                 |            |                                                                                                                                                                                                                                                                                                                     |      |       |   |
| 6<br>DSE | <p>Drive Strength Enable</p> <p>Configures drive strength, low or high, on each pin.</p> <p>The drive strength configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, low drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> <li>When this field = 1, high drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul>                                                                                                                                                                                                                                                                                                                         |                        |                             |                        |                                                                                                                                                 |            |                                                                                                                                                                                                                                                                                                                     |      |       |   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                        |                    |                        |       |       |   |       |   |       |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|-------|-------|---|-------|---|-------|
|          | <p>0b - Low<br/>1b - High</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                        |                    |                        |       |       |   |       |   |       |
| 5<br>ODE | <p>Open Drain Enable<br/>Enables open drain output on each pin.<br/>The open drain configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the open drain output is disabled on the corresponding pin.</li> <li>When this field = 1, the open drain output is enabled on the corresponding pin, if the pin is configured as a digital output.</li> </ul> <p>0b - Disables<br/>1b - Enables</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                        |                    |                        |       |       |   |       |   |       |
| 4<br>PFE | <p>Passive Filter Enable<br/>Enables passive input filter on each pin.<br/>The passive filter configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the passive input filter is disabled on the corresponding pin.</li> <li>When this field = 1, the passive input filter is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> <p>See the chip's data sheet for filter characteristics.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> <table border="1" style="width: 100%; border-collapse: collapse;"> <thead> <tr> <th>Instance</th><th>Field supported in</th><th>Field not supported in</th></tr> </thead> <tbody> <tr> <td>PORT1</td><td>PCR29</td><td>—</td></tr> <tr> <td>PORT3</td><td>—</td><td>PCR29</td></tr> </tbody> </table> <p>0b - Disables<br/>1b - Enables</p> | Instance               | Field supported in | Field not supported in | PORT1 | PCR29 | — | PORT3 | — | PCR29 |
| Instance | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Field not supported in |                    |                        |       |       |   |       |   |       |
| PORT1    | PCR29                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | —                      |                    |                        |       |       |   |       |   |       |
| PORT3    | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | PCR29                  |                    |                        |       |       |   |       |   |       |
| 3<br>SRE | <p>Slew Rate Enable<br/>Configures the slew rate feature, fast or slow, on each corresponding pin.<br/>The slew rate configuration is valid for all digital pin multiplexing modes.</p> <p>0b - Fast<br/>1b - Slow</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                        |                    |                        |       |       |   |       |   |       |
| 2        | Pull Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                        |                    |                        |       |       |   |       |   |       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                        |                    |                        |       |       |   |       |   |       |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|-------|-------|---|-------|---|-------|
| PV       | <p>Selects high or low internal pull resistor value.</p> <p>The pull value configuration is valid for all digital pin multiplexing modes.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> <table border="1" style="margin-top: 10px;"> <thead> <tr> <th>Instance</th><th>Field supported in</th><th>Field not supported in</th></tr> </thead> <tbody> <tr> <td>PORT1</td><td>PCR29</td><td>—</td></tr> <tr> <td>PORT3</td><td>—</td><td>PCR29</td></tr> </tbody> </table> <p style="text-align: center;">0b - Low<br/>1b - High</p> | Instance               | Field supported in | Field not supported in | PORT1 | PCR29 | — | PORT3 | — | PCR29 |
| Instance | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Field not supported in |                    |                        |       |       |   |       |   |       |
| PORT1    | PCR29                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | —                      |                    |                        |       |       |   |       |   |       |
| PORT3    | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | PCR29                  |                    |                        |       |       |   |       |   |       |
| 1<br>PE  | <p>Pull Enable</p> <p>Enables the internal pull resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pull resistor is not enabled on the corresponding pin.</li> <li>When this field = 1, the internal pull resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> <p style="text-align: center;">0b - Disables<br/>1b - Enables</p>                                                                                                                                                    |                        |                    |                        |       |       |   |       |   |       |
| 0<br>PS  | <p>Pull Select</p> <p>Enables the internal pullup or pulldown resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pulldown resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> <li>When this field = 1, the internal pullup resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> </ul> <p style="text-align: center;">0b - Enables internal pulldown resistor<br/>1b - Enables internal pullup resistor</p>                    |                        |                    |                        |       |       |   |       |   |       |

### 11.6.1.23 Pin Control 30 (PCR30)

#### Offset

| Register | Offset |
|----------|--------|
| PCR30    | F8h    |

#### Function

Configures pin control features on each pin.

#### NOTE

Do not modify pin configuration registers associated with pins that are unavailable in your selected package. All unbonded pins unavailable in your package default to the Disabled state for lowest power consumption.

#### NOTE

Each module instance supports a different number of registers.

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| PORTE    | —                  | PCR30                  |
| PORTE    | PCR30              | —                      |
| PORTE    | —                  | PCR30                  |
| PORTE    | PCR30              | —                      |

#### Diagram



#### Fields

| Field | Function |
|-------|----------|
| 31-16 | Reserved |
| —     |          |

Table continues on the next page...

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |                    |                        |       |       |   |       |             |           |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|-------|-------|---|-------|-------------|-----------|
| 15<br>LK    | Lock Register<br>Locks this PCR.<br>When a PCR $n$ is locked, its fields cannot be updated until the next reset.<br>0b - Does not lock<br>1b - Locks                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                        |                    |                        |       |       |   |       |             |           |
| 14<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |                    |                        |       |       |   |       |             |           |
| 13<br>INV   | Invert Input<br>Inverts the digital input.<br>0b - Does not invert<br>1b - Inverts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                        |                    |                        |       |       |   |       |             |           |
| 12<br>IBE   | Input Buffer Enable<br>Enables digital input buffer. When disabled, the digital input is required for analog functions.<br>0b - Disables<br>1b - Enables                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |                    |                        |       |       |   |       |             |           |
| 11-8<br>MUX | Pin Multiplex Control<br>Configures the multiplexing slots on each pin.<br>Not all pins support all pin multiplexing slots. Unimplemented pin multiplexing slots are reserved.<br>Unimplemented pin multiplexing slots can result in different behaviors, if the unimplemented slot is phantomed (because the module is phantomed on that die) versus unimplemented on the die.<br>The corresponding pin is configured according to the following pin multiplexing slots:<br><div style="text-align: center;"> <b>NOTE</b><br/>           This field is not supported in every instance. The following table includes only supported registers.         </div> <table border="1" style="width: 100%; border-collapse: collapse; margin-top: 10px;"> <thead> <tr> <th style="text-align: center;">Instance</th> <th style="text-align: center;">Field supported in</th> <th style="text-align: center;">Field not supported in</th> </tr> </thead> <tbody> <tr> <td style="text-align: center;">PORT1</td> <td style="text-align: center;">PCR30</td> <td style="text-align: center;">—</td> </tr> <tr> <td style="text-align: center;">PORT3</td> <td style="text-align: center;">PCR30[10-8]</td> <td style="text-align: center;">PCR30[11]</td> </tr> </tbody> </table> <div style="text-align: center;"> <b>NOTE</b><br/>           The descriptions of the field settings vary by module instance.         </div> | Instance               | Field supported in | Field not supported in | PORT1 | PCR30 | — | PORT3 | PCR30[10-8] | PCR30[11] |
| Instance    | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Field not supported in |                    |                        |       |       |   |       |             |           |
| PORT1       | PCR30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | —                      |                    |                        |       |       |   |       |             |           |
| PORT3       | PCR30[10-8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | PCR30[11]              |                    |                        |       |       |   |       |             |           |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | Instance                                                                                                                                                                                                                                                                                                                                                                 | Field value and description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|       | POR1                                                                                                                                                                                                                                                                                                                                                                     | 0000b - Alternative 0 (GPIO)<br>0001b - Alternative 1 (chip-specific)<br>0010b - Alternative 2 (chip-specific)<br>0011b - Alternative 3 (chip-specific)<br>0100b - Alternative 4 (chip-specific)<br>0101b - Alternative 5 (chip-specific)<br>0110b - Alternative 6 (chip-specific)<br>0111b - Alternative 7 (chip-specific)<br>1000b - Alternative 8 (chip-specific)<br>1001b - Alternative 9 (chip-specific)<br>1010b - Alternative 10 (chip-specific)<br>1011b - Alternative 11 (chip-specific)<br>1100b - Alternative 12 (chip-specific) |
|       | POR3                                                                                                                                                                                                                                                                                                                                                                     | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)<br>110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific)                                                                                                                                                                                                                         |
| 7     | <b>DSE1</b><br>Drive Strength Enable<br>Configures the drive strength on each pin.<br>The drive strength configuration is valid for all digital pin multiplexing modes.                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|       | <ul style="list-style-type: none"> <li>• If this field = 0, normal drive strength is configured on the corresponding pin.</li> <li>• If this field = 1, double drive strength is configured on the corresponding pin.</li> </ul> <p><b>NOTE</b><br/>           This field is not supported in every instance. The following table includes only supported registers.</p> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                                                                                                                | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                    |                        |
|----------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------------------|
|                                                                                                                      | Instance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Field supported in | Field not supported in |
|                                                                                                                      | POR1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | PCR30              | —                      |
|                                                                                                                      | POR3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | —                  | PCR30                  |
|                                                                                                                      | 0b - Normal<br>1b - Double                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                    |                        |
| 6<br>DSE                                                                                                             | <b>Drive Strength Enable</b><br>Configures drive strength, low or high, on each pin.<br>The drive strength configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, low drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> <li>When this field = 1, high drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul> 0b - Low<br>1b - High |                    |                        |
| 5<br>ODE                                                                                                             | <b>Open Drain Enable</b><br>Enables open drain output on each pin.<br>The open drain configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, the open drain output is disabled on the corresponding pin.</li> <li>When this field = 1, the open drain output is enabled on the corresponding pin, if the pin is configured as a digital output.</li> </ul> 0b - Disables<br>1b - Enables                                                             |                    |                        |
| 4<br>PFE                                                                                                             | <b>Passive Filter Enable</b><br>Enables passive input filter on each pin.<br>The passive filter configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, the passive input filter is disabled on the corresponding pin.</li> <li>When this field = 1, the passive input filter is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> See the chip's data sheet for filter characteristics.                     |                    |                        |
| <b>NOTE</b><br>This field is not supported in every instance. The following table includes only supported registers. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                    |                        |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                        |                        |          |                    |                        |       |       |   |       |   |       |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|------------------------|----------|--------------------|------------------------|-------|-------|---|-------|---|-------|
|          | Instance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Field supported in     | Field not supported in |          |                    |                        |       |       |   |       |   |       |
|          | PORT1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | PCR30                  | —                      |          |                    |                        |       |       |   |       |   |       |
|          | PORT3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | —                      | PCR30                  |          |                    |                        |       |       |   |       |   |       |
|          | 0b - Disables<br>1b - Enables                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                        |                        |          |                    |                        |       |       |   |       |   |       |
| 3<br>SRE | <b>Slew Rate Enable</b><br>Configures the slew rate feature, fast or slow, on each corresponding pin.<br>The slew rate configuration is valid for all digital pin multiplexing modes.<br>0b - Fast<br>1b - Slow                                                                                                                                                                                                                                                                                                                                                                                        |                        |                        |          |                    |                        |       |       |   |       |   |       |
| 2<br>PV  | <b>Pull Value</b><br>Selects high or low internal pull resistor value.<br>The pull value configuration is valid for all digital pin multiplexing modes. <p style="text-align: center;"><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> <table border="1"> <thead> <tr> <th>Instance</th> <th>Field supported in</th> <th>Field not supported in</th> </tr> </thead> <tbody> <tr> <td>PORT1</td> <td>PCR30</td> <td>—</td></tr> <tr> <td>PORT3</td> <td>—</td> <td>PCR30</td></tr> </tbody> </table> 0b - Low<br>1b - High |                        |                        | Instance | Field supported in | Field not supported in | PORT1 | PCR30 | — | PORT3 | — | PCR30 |
| Instance | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Field not supported in |                        |          |                    |                        |       |       |   |       |   |       |
| PORT1    | PCR30                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | —                      |                        |          |                    |                        |       |       |   |       |   |       |
| PORT3    | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | PCR30                  |                        |          |                    |                        |       |       |   |       |   |       |
| 1<br>PE  | <b>Pull Enable</b><br>Enables the internal pull resistor.<br>This configuration is valid for all digital pin multiplexing modes. <ul style="list-style-type: none"> <li>When this field = 0, the internal pull resistor is not enabled on the corresponding pin.</li> <li>When this field = 1, the internal pull resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> 0b - Disables<br>1b - Enables                                                                                                                                                   |                        |                        |          |                    |                        |       |       |   |       |   |       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>PS | <p>Pull Select</p> <p>Enables the internal pullup or pulldown resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pulldown resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> <li>When this field = 1, the internal pullup resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> </ul> <p>0b - Enables internal pulldown resistor</p> <p>1b - Enables internal pullup resistor</p> |

#### 11.6.1.24 Pin Control 31 (PCR31)

##### Offset

| Register | Offset |
|----------|--------|
| PCR31    | FCh    |

##### Function

Configures pin control features on each pin.

---

##### NOTE

Do not modify pin configuration registers associated with pins that are unavailable in your selected package. All unbonded pins unavailable in your package default to the Disabled state for lowest power consumption.

---

##### NOTE

Each module instance supports a different number of registers.

| Instance | Register supported | Register not supported |
|----------|--------------------|------------------------|
| PORT0    | —                  | PCR31                  |
| PORT1    | PCR31              | —                      |
| PORT2    | —                  | PCR31                  |
| PORT3    | PCR31              | —                      |

**Diagram**

| Bits  | 31 | 30 | 29  | 28  | 27  | 26 | 25 | 24 | 23   | 22  | 21  | 20  | 19  | 18 | 17 | 16 |
|-------|----|----|-----|-----|-----|----|----|----|------|-----|-----|-----|-----|----|----|----|
| R     | 0  |    |     |     |     |    |    |    |      |     |     |     |     |    |    |    |
| W     |    |    |     |     |     |    |    |    |      |     |     |     |     |    |    |    |
| Reset | 0  | 0  | 0   | 0   | 0   | 0  | 0  | 0  | 0    | 0   | 0   | 0   | 0   | 0  | 0  | 0  |
| Bits  | 15 | 14 | 13  | 12  | 11  | 10 | 9  | 8  | 7    | 6   | 5   | 4   | 3   | 2  | 1  | 0  |
| R     | LK | 0  | INV | IBE | MUX |    |    |    | DSE1 | DSE | ODE | PFE | SRE | 0  | PE | PS |
| W     |    |    |     |     |     |    |    |    |      |     |     |     |     |    |    |    |
| Reset | 0  | 0  | 0   | 0   | 0   | 0  | 0  | 0  | 0    | 0   | 0   | 0   | 0   | 0  | 0  | 0  |

**Fields**

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 15<br>LK    | <p>Lock Register</p> <p>Locks this PCR.</p> <p>When a PCR<math>n</math> is locked, its fields cannot be updated until the next reset.</p> <p>0b - Does not lock</p> <p>1b - Locks</p>                                                                                                                                                                                                              |
| 14<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 13<br>INV   | <p>Invert Input</p> <p>Inverts the digital input.</p> <p>0b - Does not invert</p> <p>1b - Inverts</p>                                                                                                                                                                                                                                                                                              |
| 12<br>IBE   | <p>Input Buffer Enable</p> <p>Enables digital input buffer. When disabled, the digital input is required for analog functions.</p> <p>0b - Disables</p> <p>1b - Enables</p>                                                                                                                                                                                                                        |
| 11-8<br>MUX | <p>Pin Multiplex Control</p> <p>Configures the multiplexing slots on each pin.</p> <p>Not all pins support all pin multiplexing slots. Unimplemented pin multiplexing slots are reserved.</p> <p>Unimplemented pin multiplexing slots can result in different behaviors, if the unimplemented slot is phantomed (because the module is phantomed on that die) versus unimplemented on the die.</p> |

*Table continued from the previous page...*

| Field                                                                                                                                                                                                                                                     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                        |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| <p>The corresponding pin is configured according to the following pin multiplexing slots:</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                        |
|                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                        |
| Instance                                                                                                                                                                                                                                                  | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Field not supported in |
| PORT1                                                                                                                                                                                                                                                     | PCR31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | —                      |
| PORT3                                                                                                                                                                                                                                                     | PCR31[10–8]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | PCR31[11]              |
| <p style="text-align: center;"><b>NOTE</b></p> <p>The descriptions of the field settings vary by module instance.</p>                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                        |
| Instance                                                                                                                                                                                                                                                  | Field value and description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                        |
| PORT1                                                                                                                                                                                                                                                     | 0000b - Alternative 0 (GPIO)<br>0001b - Alternative 1 (chip-specific)<br>0010b - Alternative 2 (chip-specific)<br>0011b - Alternative 3 (chip-specific)<br>0100b - Alternative 4 (chip-specific)<br>0101b - Alternative 5 (chip-specific)<br>0110b - Alternative 6 (chip-specific)<br>0111b - Alternative 7 (chip-specific)<br>1000b - Alternative 8 (chip-specific)<br>1001b - Alternative 9 (chip-specific)<br>1010b - Alternative 10 (chip-specific)<br>1011b - Alternative 11 (chip-specific)<br>1100b - Alternative 12 (chip-specific) |                        |
| PORT3                                                                                                                                                                                                                                                     | 000b - Alternative 0 (GPIO)<br>001b - Alternative 1 (chip-specific)<br>010b - Alternative 2 (chip-specific)<br>011b - Alternative 3 (chip-specific)<br>100b - Alternative 4 (chip-specific)<br>101b - Alternative 5 (chip-specific)                                                                                                                                                                                                                                                                                                         |                        |

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                              |          |                    |                        |       |       |   |       |   |       |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|----------|--------------------|------------------------|-------|-------|---|-------|---|-------|
|           | Instance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Field value and description                                                  |          |                    |                        |       |       |   |       |   |       |
|           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 110b - Alternative 6 (chip-specific)<br>111b - Alternative 7 (chip-specific) |          |                    |                        |       |       |   |       |   |       |
|           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                              |          |                    |                        |       |       |   |       |   |       |
| 7<br>DSE1 | <p>Drive Strength Enable</p> <p>Configures the drive strength on each pin.</p> <p>The drive strength configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>• If this field = 0, normal drive strength is configured on the corresponding pin.</li> <li>• If this field = 1, double drive strength is configured on the corresponding pin.</li> </ul> <p><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p>       |                                                                              |          |                    |                        |       |       |   |       |   |       |
|           | <table border="1"> <thead> <tr> <th>Instance</th> <th>Field supported in</th> <th>Field not supported in</th> </tr> </thead> <tbody> <tr> <td>PORT1</td> <td>PCR31</td> <td>—</td> </tr> <tr> <td>PORT3</td> <td>—</td> <td>PCR31</td> </tr> </tbody> </table>                                                                                                                                                                                                                                                                                 |                                                                              | Instance | Field supported in | Field not supported in | PORT1 | PCR31 | — | PORT3 | — | PCR31 |
| Instance  | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Field not supported in                                                       |          |                    |                        |       |       |   |       |   |       |
| PORT1     | PCR31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | —                                                                            |          |                    |                        |       |       |   |       |   |       |
| PORT3     | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | PCR31                                                                        |          |                    |                        |       |       |   |       |   |       |
|           | <p>0b - Normal</p> <p>1b - Double</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                              |          |                    |                        |       |       |   |       |   |       |
| 6<br>DSE  | <p>Drive Strength Enable</p> <p>Configures drive strength, low or high, on each pin.</p> <p>The drive strength configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>• When this field = 0, low drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> <li>• When this field = 1, high drive strength is configured on the corresponding pin, if the pin is configured as a digital output.</li> </ul> <p>0b - Low</p> <p>1b - High</p> |                                                                              |          |                    |                        |       |       |   |       |   |       |
| 5<br>ODE  | <p>Open Drain Enable</p> <p>Enables open drain output on each pin.</p> <p>The open drain configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>• When this field = 0, the open drain output is disabled on the corresponding pin.</li> </ul>                                                                                                                                                                                                                                               |                                                                              |          |                    |                        |       |       |   |       |   |       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                        |                    |                        |       |       |   |       |   |       |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|-------|-------|---|-------|---|-------|
|          | <ul style="list-style-type: none"> <li>When this field = 1, the open drain output is enabled on the corresponding pin, if the pin is configured as a digital output.</li> </ul> <p>0b - Disables<br/>1b - Enables</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                        |                    |                        |       |       |   |       |   |       |
| 4<br>PFE | <p>Passive Filter Enable</p> <p>Enables passive input filter on each pin.</p> <p>The passive filter configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the passive input filter is disabled on the corresponding pin.</li> <li>When this field = 1, the passive input filter is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> <p>See the chip's data sheet for filter characteristics.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> <table border="1" style="margin-left: auto; margin-right: auto;"> <thead> <tr> <th>Instance</th><th>Field supported in</th><th>Field not supported in</th></tr> </thead> <tbody> <tr> <td>PORT1</td><td>PCR31</td><td>—</td></tr> <tr> <td>PORT3</td><td>—</td><td>PCR31</td></tr> </tbody> </table> <p>0b - Disables<br/>1b - Enables</p> | Instance               | Field supported in | Field not supported in | PORT1 | PCR31 | — | PORT3 | — | PCR31 |
| Instance | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Field not supported in |                    |                        |       |       |   |       |   |       |
| PORT1    | PCR31                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | —                      |                    |                        |       |       |   |       |   |       |
| PORT3    | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | PCR31                  |                    |                        |       |       |   |       |   |       |
| 3<br>SRE | <p>Slew Rate Enable</p> <p>Configures the slew rate feature, fast or slow, on each corresponding pin.</p> <p>The slew rate configuration is valid for all digital pin multiplexing modes.</p> <p>0b - Fast<br/>1b - Slow</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                        |                    |                        |       |       |   |       |   |       |
| 2<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                        |                    |                        |       |       |   |       |   |       |
| 1<br>PE  | <p>Pull Enable</p> <p>Enables the internal pull resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pull resistor is not enabled on the corresponding pin.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                        |                    |                        |       |       |   |       |   |       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | <ul style="list-style-type: none"> <li>When this field = 1, the internal pull resistor is enabled on the corresponding pin, if the pin is configured as a digital input.</li> </ul> <p>0b - Disables<br/>1b - Enables</p>                                                                                                                                                                                                                                                                                                                                                                            |
| 0<br>PS | <p>Pull Select</p> <p>Enables the internal pullup or pulldown resistor.</p> <p>This configuration is valid for all digital pin multiplexing modes.</p> <ul style="list-style-type: none"> <li>When this field = 0, the internal pulldown resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> <li>When this field = 1, the internal pullup resistor is enabled on the corresponding pin, if the corresponding PCR<math>n</math>.PE field = 1.</li> </ul> <p>0b - Enables internal pulldown resistor<br/>1b - Enables internal pullup resistor</p> |

# Chapter 12

## General Purpose Input/Output (GPIO)

### 12.1 Chip-specific GPIO information

Table 63. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | GPIO           | <a href="#">GPIO</a>                |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 12.1.1 Module instances

This device has four instances of the GPIO module, GPIO0, GPIO1, GPIO2, and GPIO3.

#### 12.1.2 Interrupt, DMA request, and trigger outputs for GPIO

GPIO modules can be used to trigger interrupts, DMA requests, or trigger outputs (see the INPUTMUX and WUU chapters for details). See the table below for details on the chip-level interrupt, DMA request, and trigger output capability for each GPIO instance.

Table 64. Interrupt, DMA request, and trigger outputs for GPIO

| GPIO  | Interrupt | DMA | Trigger |
|-------|-----------|-----|---------|
| GPIO0 | Yes       | Yes | Yes     |
| GPIO1 | Yes       | Yes | Yes     |
| GPIO2 | Yes       | Yes | Yes     |
| GPIO3 | Yes       | Yes | Yes     |

### 12.2 Overview

GPIO communicates to the processor core via a zero wait-state interface for maximum pin performance.

### 12.2.1 Block diagram



Figure 15. Block diagram

### 12.2.2 Features

- **Port Data Input (PDIR)** displays the logic value on each pin when the pin is configured for any digital function, provided the corresponding Port Control and Interrupt modules for that pin are enabled.
- **Port Data Output (PDOR)**, with corresponding set, clear, and toggle registers, controls the output data of each pin when the pin is configured for the GPIO function.
- **Port Data Direction (PDDR)** controls the direction of each pin when the pin is configured for the GPIO function.
- **Port Input Disable (PIDR)** controls disabling of the input for each general-purpose pin.
- Pin interrupts:
  - Interrupt flags and enable registers for each pin are functional in all digital pin muxing modes.
  - Support for interrupt, peripheral trigger, or DMA request is configured for each pin.
  - Support for edge-sensitive (rising, falling, or both) or level-sensitive (low, high) interrupts is configured for each pin.
  - Asynchronous wake-up in Low-Power mode.
  - GPIO generates a total of 1 interrupts, 1 output triggers, and 1 DMA requests.

## 12.3 Functional description

### 12.3.1 Low-Power mode

You can configure GPIO to exit Low-Power mode via an asynchronous wake-up signal if an enabled interrupt is detected.

### 12.3.2 Debug mode

GPIO remains functional in Debug mode.

### 12.3.3 General-purpose input

The logic state of each pin is available via **Port Data Input (PDIR)** if:

- The corresponding field in **Port Input Disable (PIDR)** is 0.
- The pin is configured for a digital function.

### 12.3.4 General-purpose output

The logic state of each pin is controlled via [Port Data Output \(PDOR\)](#) and [Port Data Direction \(PDDR\)](#), provided the pin is configured for the GPIO function. The following table depicts the conditions for a pin to be configured as input or output.

**Table 65. General-purpose output**

| If                                                                              | Then                                                                                                        |
|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|
| A pin is configured for the GPIO function and the corresponding PDDR field is 0 | The pin is configured as an input.                                                                          |
| A pin is configured for the GPIO function and the corresponding PDDR field is 1 | The pin is configured as an output and the logic state of the pin is equal to the corresponding PDOR field. |

For efficient bit manipulation on the general-purpose outputs, pin data set, pin data clear, and pin data toggle registers allow one or more outputs within one port to be set, cleared, or toggled from a single register write, eliminating the need for a read-modify-write operation to prevent changing pins accidentally.

### 12.3.5 Clocking

GPIO receives a single clock, which is used for register access and synchronization with external pin inputs. There are no special considerations.

### 12.3.6 Reset

GPIO receives a single reset, which resets the peripheral. There are no special considerations.

### 12.3.7 External interrupts

The external interrupt capability of GPIO is available in all digital pin muxing modes.

You can configure each pin individually for any of the external interrupt modes shown in the following table.

**Table 66. Available pin configurations for external interrupts**

| Signal conditions        | Software polling using flags | Peripheral triggers | Interrupts | DMA requests |
|--------------------------|------------------------------|---------------------|------------|--------------|
| Rising-edge              | Yes                          | —                   | Yes        | Yes          |
| Falling-edge             | Yes                          | —                   | Yes        | Yes          |
| Rising- and falling-edge | Yes                          | —                   | Yes        | Yes          |
| High-level               | —                            | Yes                 | Yes        | —            |
| Low-level                | —                            | Yes                 | Yes        | —            |

The interrupt status flag is set when the configured edge or level is detected on the pin. Unless GPIO is in Low-Power mode, the input is first synchronized to the system clock to detect the configured level or edge transition.

GPIO generates a pin interrupt that asserts when the interrupt status flag is set for any enabled interrupt for that output. The interrupt negates after the interrupt status flags for all enabled interrupts are cleared by writing a logic 1 to either [ISFR0\[ISFn\]](#) or [ICR0\[ISF\]](#).

GPIO generates a DMA request that asserts when the interrupt status flag is set for any enabled DMA request in that output. The DMA request negates after the DMA transfer is completed because that clears the interrupt status flags for all enabled DMA requests.

In Low-Power mode, the interrupt status flag for any enabled interrupt is asynchronously set if the required level or edge is detected. This also generates an asynchronous wake-up signal to exit Low-Power mode.

GPIO generates a peripheral trigger output that asserts if any pin configured for the active-high trigger is logic 1, or any pin triggered for the active-low trigger is logic 0. The peripheral trigger output asynchronously updates from the value on the configured pins.

### 12.3.8 Global interrupt control

The two global interrupt control registers ([Global Interrupt Control Low \(GICLR\)](#) and [Global Interrupt Control High \(GICHR\)](#)) allow a single register write to update the upper 16 bits of [Interrupt Control a \(ICR0 - ICR31\)](#) for up to 16 pins, all with the same value.

These global interrupt control registers allow you to quickly configure multiple pins within the same port with the same interrupt configuration.

The global interrupt control registers are write-only registers and always read 0.

### 12.3.9 DMA

GPIO generates 1 requests. For each pin, you can configure DMA requests to assert for either rising, falling, or both edge detection. See [External interrupts](#) for more information.

### 12.3.10 Access protection

GPIO implements access protection registers (PCNS and PCNP) for each pin, as shown in [Table 67](#).

**Table 67. PCNS and PCNP register access protection implementation**

| Access       | Description                                                                                                 |
|--------------|-------------------------------------------------------------------------------------------------------------|
| Secure       | You can write to or read the pins configured for secure access only in the Secure state.                    |
| Nonsecure    | You can write to or read the pins configured for nonsecure access only in the Nonsecure state.              |
| Privilege    | You can write to the pins configured for privilege access only in the Privilege state.                      |
| Nonprivilege | You can write to the pins configured for nonprivilege access in both the Privilege and Nonprivilege states. |

GPIO implements access protection registers (ICNS and ICNP) for each interrupt, trigger output, and DMA request as shown in [Table 68](#).

**Table 68. ICNS and ICNP register access protection implementation**

| Access       | Description                                                                                                     |
|--------------|-----------------------------------------------------------------------------------------------------------------|
| Secure       | You can configure the outputs programmed for secure access only in the Secure state.                            |
| Nonsecure    | You can configure the outputs programmed for nonsecure access only in the Nonsecure state.                      |
| Privilege    | You can configure the outputs programmed for privilege access only in the Privilege state.                      |
| Nonprivilege | You can configure the outputs programmed for nonprivilege access in both the Privilege and Nonprivilege states. |

You can write to the access protection registers (PCNS, PCNP, ICNS, and ICNP) only in the Secure-Privilege state; you can optionally lock these registers until the next reset.

Configuring a pin interrupt, trigger output, or DMA request requires the following access permissions:

- Access permission to configure the pin.
- The interrupt configuration is not locked.

## 12.4 External signals

Table 69. External signals

| Signal       | Description                  |                                                                                                                                                                                                                                                                                                                                                                                    | Direction |
|--------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| GPIO31–GPIO0 | General-purpose input/output |                                                                                                                                                                                                                                                                                                                                                                                    | I/O       |
|              | State meaning                | Asserted: The pin is logic 1.<br>Deasserted: The pin is logic 0.                                                                                                                                                                                                                                                                                                                   |           |
|              | Timing                       | Assertion: When output, this signal occurs on the rising-edge of the system clock. For input, it may occur at any time and input may be asserted asynchronously to the system clock.<br><br>Deassertion: When output, this signal occurs on the rising-edge of the system clock. For input, it may occur at any time and input may be asserted asynchronously to the system clock. |           |

**NOTE**

Not all pins within each GPIO are implemented on each chip. See the "Signal Multiplexing" chapter for the number of GPIO pins within each port available on this chip.

## 12.5 Initialization

To initialize GPIO:

1. Initialize the GPIO pins for the output function:
  - a. Configure the output logic value for each pin by using [Port Data Output \(PDOR\)](#).
  - b. Configure the direction for each pin by using [Port Data Direction \(PDDR\)](#).
2. Initialize the interrupt function by writing to [Interrupt Control a \(ICR0 - ICR31\)](#) for the corresponding pins and desired configuration. If the pin is previously used for a different function, first write 0100\_0000h to [Interrupt Control a \(ICR0 - ICR31\)](#) to disable the previous function and clear the flag.

## 12.6 Application information

GPIO includes the following applications:

- Reading the state of a single pin by performing a byte read of [Pin Data \(P0DR - P31DR\)](#).
- Updating the state of a single pin by performing a byte write to [Pin Data \(P0DR - P31DR\)](#).
- Reading the state of multiple pins by reading [Port Data Input \(PDIR\)](#).
- Updating the state of multiple pins by using the following ways:
  - Writing to [Port Data Output \(PDOR\)](#).
  - Writing to [Port Set Output \(PSOR\)](#) to write 1 to [Port Data Output \(PDOR\)](#).
  - Writing to [Port Clear Output \(PCOR\)](#) to write 0 to [Port Data Output \(PDOR\)](#).
  - Writing to [Port Toggle Output \(PTOR\)](#) to toggle [Port Data Output \(PDOR\)](#).

## 12.7 Memory map and register definition

The GPIO registers support 8-bit, 16-bit, or 32-bit accesses. Any read or write access to the GPIO memory space that is outside the valid memory map results in a bus error.

**NOTE**

For simplicity, each GPIO port's register appears with the same width of 32 bits, corresponding to 32 pins. The actual number of pins per port (and therefore the number of usable control bits per port register) is chip-specific. See the "Signal Multiplexing" chapter for the exact control bits of each port.

## 12.7.1 GPIO register descriptions

### 12.7.1.1 GPIO memory map

RGPIO0 base address: 4010\_2000h

RGPIO1 base address: 4010\_3000h

RGPIO2 base address: 4010\_4000h

RGPIO3 base address: 4010\_5000h

| Offset    | Register                              | Width<br>(In bits) | Access | Reset value |
|-----------|---------------------------------------|--------------------|--------|-------------|
| 0h        | Version ID (VERID)                    | 32                 | R      | 0201_0000h  |
| 4h        | Parameter (PARAM)                     | 32                 | R      | 0000_0001h  |
| 40h       | Port Data Output (PDOR)               | 32                 | RW     | 0000_0000h  |
| 44h       | Port Set Output (PSOR)                | 32                 | W      | 0000_0000h  |
| 48h       | Port Clear Output (PCOR)              | 32                 | W      | 0000_0000h  |
| 4Ch       | Port Toggle Output (PTOR)             | 32                 | W      | 0000_0000h  |
| 50h       | Port Data Input (PDIR)                | 32                 | R      | 0000_0000h  |
| 54h       | Port Data Direction (PDDR)            | 32                 | RW     | 0000_0000h  |
| 58h       | Port Input Disable (PIDR)             | 32                 | RW     | 0000_0000h  |
| 60h - 7Fh | Pin Data (P0DR - P31DR)               | 8                  | RW     | 00h         |
| 80h - FCh | Interrupt Control a (ICR0 - ICR31)    | 32                 | RW     | 0000_0000h  |
| 100h      | Global Interrupt Control Low (GICLR)  | 32                 | W      | 0000_0000h  |
| 104h      | Global Interrupt Control High (GICHR) | 32                 | W      | 0000_0000h  |
| 120h      | Interrupt Status Flag (ISFR0)         | 32                 | RW     | 0000_0000h  |

### 12.7.1.2 Version ID (VERID)

#### Offset

| Register | Offset |
|----------|--------|
| VERID    | 0h     |

#### Function

Indicates the version ID number of each GPIO.

**Diagram**

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

**Fields**

| Field           | Function                                                                                                                                                                        |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24<br>MAJOR  | Major Version Number<br>Indicates the major version number for the specification.                                                                                               |
| 23-16<br>MINOR  | Minor Version Number<br>Indicates the minor version number for the specification.                                                                                               |
| 15-0<br>FEATURE | Feature Specification Number<br>Indicates the feature set number.<br><br>0000_0000_0000_0000b - Basic implementation<br>0000_0000_0000_0001b - Protection registers implemented |

**12.7.1.3 Parameter (PARAM)****Offset**

| Register | Offset |
|----------|--------|
| PARAM    | 4h     |

**Function**

Indicates the interrupt number of each GPIO.

**Diagram**

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

**Fields**

| Field  | Function                                                            |
|--------|---------------------------------------------------------------------|
| 31-4   | Reserved                                                            |
| —      |                                                                     |
| 3-0    | Interrupt Number                                                    |
| IRQNUM | Indicates the number of interrupt, trigger, or DMA request domains. |

**12.7.1.4 Port Data Output (PDOR)****Offset**

| Register | Offset |
|----------|--------|
| PDOR     | 40h    |

**Function**

Configures the logic levels that are driven on each general-purpose output pin.

**NOTE**

Do not modify the pin configuration registers associated with pins that are not available in your selected package.  
By default, these unbonded pins are set to the Disable state for lowest power consumption.

**Diagram**

| Bits  | 31   | 30   | 29   | 28   | 27   | 26   | 25   | 24   | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|-------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
| R     | PDO3 | PDO3 | PDO2 | PDO1 | PDO1 | PDO1 | PDO1 |
| W     | 1    | 0    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    | 9    | 8    | 7    | 6    |
| Reset | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |
| Bits  | 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| R     | PDO1 | PDO1 | PDO1 | PDO1 | PDO1 | PDO1 | PDO9 | PDO8 | PDO7 | PDO6 | PDO5 | PDO4 | PDO3 | PDO2 | PDO1 | PDO0 |
| W     | 5    | 4    | 3    | 2    | 1    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |
| Reset | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

**Fields**

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>PDOn | <p>Port Data Output</p> <p>Configures the logic level on the pin if it is configured for general-purpose output. If this field is 0, logic level 0 is driven on the pin, if the pin is configured for general-purpose output. If this field is 1, logic level 1 is driven on the pin, if the pin is configured for general-purpose output.</p> <p><b>NOTE</b><br/>Reading the fields for unbonded pins returns an undefined value.</p> <p>0b - Logic level 0<br/>1b - Logic level 1</p> |

**12.7.1.5 Port Set Output (PSOR)****Offset**

| Register | Offset |
|----------|--------|
| PSOR     | 44h    |

**Function**

Updates the corresponding fields of [Port Data Output \(PDOR\)](#) to become 1.

**Diagram**

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

**Fields**

| Field        | Function                                                                                                                                                                                                                                                                                                                       |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>PTSO | <p>Port Set Output</p> <p>Updates the content of the corresponding field in <a href="#">Port Data Output (PDOR)</a>. If this field is 0, the corresponding PDOR field does not change. If this field is 1, the corresponding PDOR field becomes 1.</p> <p>0b - No change</p> <p>1b - Corresponding field in PDOR becomes 1</p> |

**12.7.1.6 Port Clear Output (PCOR)****Offset**

| Register | Offset |
|----------|--------|
| PCOR     | 48h    |

**Function**

Updates the corresponding fields of [Port Data Output \(PDOR\)](#) to become 0.

**Diagram**

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

**Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                               |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>PTCON | Port Clear Output<br><br>Updates the content of the corresponding field in <a href="#">Port Data Output (PDOR)</a> . If this field is 0, the corresponding PDOR field does not change. If this field is 1, the corresponding PDOR field becomes 0.<br><br>0b - No change<br>1b - Corresponding field in PDOR becomes 0 |

**12.7.1.7 Port Toggle Output (PTOR)****Offset**

| Register | Offset |
|----------|--------|
| PTOR     | 4Ch    |

**Function**

Updates the corresponding fields of [Port Data Output \(PDOR\)](#) to set to the inverse of their current logic states.

**Diagram**

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

**Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>PTTOn | <p>Port Toggle Output</p> <p>Updates the content of the corresponding field in <a href="#">Port Data Output (PDOR)</a>. If this field is 0, the corresponding PDOR field does not change. If this field is 1, the corresponding PDOR field is set to the inverse of its current logic state.</p> <p>0b - No change</p> <p>1b - Set to the inverse of its current logic state</p> |

**12.7.1.8 Port Data Input (PDIR)****Offset**

| Register | Offset |
|----------|--------|
| PDIR     | 50h    |

**Function**

Captures the logic levels of each general-purpose input pin.

**NOTE**

Do not modify the pin configuration registers associated with the pins that are not available in your selected package. By default, these unbonded pins are set to the Disable state for lowest power consumption.

**Diagram**

| Bits  | 31    | 30    | 29    | 28    | 27    | 26    | 25    | 24    | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| R     | PDI31 | PDI30 | PDI29 | PDI28 | PDI27 | PDI26 | PDI25 | PDI24 | PDI23 | PDI22 | PDI21 | PDI20 | PDI19 | PDI18 | PDI17 | PDI16 |
| W     |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| Bits  | 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| R     | PDI15 | PDI14 | PDI13 | PDI12 | PDI11 | PDI10 | PDI9  | PDI8  | PDI7  | PDI6  | PDI5  | PDI4  | PDI3  | PDI2  | PDI1  | PDI0  |
| W     |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |       |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

**Fields**

| Field        | Function                                                                                                                                                                                                                                                                                                                               |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>PDIn | <p>Port Data Input</p> <p>Indicates the logic level of the pin that is configured for use by a digital function. If this field is 0, the pin logic level is logic 0 or is not configured or implemented for use by a digital function. If this field is 1, the pin logic level is logic 1.</p> <p>0b - Logic 0</p> <p>1b - Logic 1</p> |

**12.7.1.9 Port Data Direction (PDDR)****Offset**

| Register | Offset |
|----------|--------|
| PDDR     | 54h    |

**Function**

Configures the individual port pins for input or output.

**Diagram**

| Bits  | 31   | 30   | 29   | 28   | 27   | 26   | 25   | 24   | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|-------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|------|
| R     | PDD3 | PDD3 | PDD2 | PDD1 | PDD1 | PDD1 | PDD1 |
| W     | 1    | 0    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    | 9    | 8    | 7    | 6    |
| Reset | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |
| Bits  | 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| R     | PDD1 | PDD1 | PDD1 | PDD1 | PDD1 | PDD1 | PDD9 | PDD8 | PDD7 | PDD6 | PDD5 | PDD4 | PDD3 | PDD2 | PDD1 | PDD0 |
| W     | 5    | 4    | 3    | 2    | 1    | 0    |      |      |      |      |      |      | 0    | 0    | 0    | 0    |
| Reset | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

**Fields**

| Field        | Function                                                                                                                                                                                                                                                                                                      |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>PDDn | <p>Port Data Direction</p> <p>Configures individual port pins for input or output. If this field is 0, the pin is configured as general-purpose input for the GPIO function. If this field is 1, the pin is configured as general-purpose output for the GPIO function.</p> <p>0b - Input<br/>1b - Output</p> |

**12.7.1.10 Port Input Disable (PIDR)****Offset**

| Register | Offset |
|----------|--------|
| PIDR     | 58h    |

**Function**

Disables the input for each general-purpose pin, which prevents the value from being reported in [Port Data Input \(PDIR\)](#).

**Diagram**

| Bits  | 31    | 30    | 29    | 28    | 27    | 26    | 25    | 24    | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| R     | PID31 | PID30 | PID29 | PID28 | PID27 | PID26 | PID25 | PID24 | PID23 | PID22 | PID21 | PID20 | PID19 | PID18 | PID17 | PID16 |
| W     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| Bits  | 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| R     | PID15 | PID14 | PID13 | PID12 | PID11 | PID10 | PID9  | PID8  | PID7  | PID6  | PID5  | PID4  | PID3  | PID2  | PID1  | PID0  |
| W     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

**Fields**

| Field        | Function                                                                                                                                                                                                                                                                                                                                                               |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>PIDn | <p>Port Input Disable</p> <p>Disables a pin for general-purpose input. If this field is 0, the pin is configured for general-purpose input, provided the pin is configured for a digital function. If this field is 1, the pin is disabled for general-purpose input.</p> <p>0b - Configured for general-purpose input<br/>1b - Disabled for general-purpose input</p> |

### 12.7.1.11 Pin Data (P0DR - P31DR)

#### Offset

For  $a = 0$  to 31:

| Register | Offset                  |
|----------|-------------------------|
| PaDR     | 60h + ( $a \times 1h$ ) |

#### Function

Configures the data feature of a pin. Pins that are unimplemented or not configured for a digital function read zero.

#### NOTE

You must not modify [Pin Data \(P0DR - P31DR\)](#) associated with the pins that are not available in your selected package. These unbonded pins are, by default, set to the Disable state for lowest power consumption.

#### Diagram



#### Fields

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-1<br>— | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0<br>PD  | Pin Data (I/O)<br>Specifies the pin logic level. This field updates the corresponding field in <a href="#">Port Data Output (PDOR)</a> ; reading this field returns the value in the corresponding field of <a href="#">Port Data Input (PDIR)</a> . If this field is 0, the pin logic level is logic zero or not configured for use by a digital function. If this field is 1, the pin logic level is logic one.<br>0b - Logic zero<br>1b - Logic one |

### 12.7.1.12 Interrupt Control a (ICR0 - ICR31)

#### Offset

For  $a = 0$  to 31:

| Register | Offset                  |
|----------|-------------------------|
| ICRa     | 80h + ( $a \times 4h$ ) |

**Function**

Configures interrupt features on each pin.

**Diagram**

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

**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-25<br>— | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 24<br>ISF  | <p>Interrupt Status Flag</p> <p>Indicates whether the configured interrupt is detected. The pin interrupt configuration is valid in all digital pin muxing modes.</p> <p>The fields in <a href="#">Interrupt Status Flag (ISFR0)</a> have the same function. ISF can be cleared with either register field.</p> <p>If the pin is configured to generate a DMA request, then the corresponding flag is cleared automatically at the completion of the requested DMA transfer. Otherwise, the flag remains set until a logic 1 is written to the flag. If the pin is configured for a level-sensitive interrupt and the pin remains asserted, then the flag is set again immediately after it is cleared.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - Not detected</li> <li>1b - Detected</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul> |
| 23<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22-20<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 19-16<br>IRQC | <p>Interrupt Configuration</p> <p>Specifies the ISF and DMA request configuration. The pin interrupt configuration is valid in all digital pin muxing modes. When changing the interrupt configuration, it is recommended to first disable ISF and then write the new configuration. The corresponding pin is configured to generate interrupt, trigger, or DMA request.</p> <p><b>NOTE</b><br/>See the GPIO chip-specific information to determine the GPIO instances that support interrupt, DMA request, or trigger capabilities.</p> <ul style="list-style-type: none"> <li>0000b - ISF is disabled</li> <li>0001b - ISF and DMA request on rising edge</li> <li>0010b - ISF and DMA request on falling edge</li> <li>0011b - ISF and DMA request on either edge</li> <li>0100b - Reserved</li> <li>0101b - ISF sets on rising edge</li> <li>0110b - ISF sets on falling edge</li> <li>0111b - ISF sets on either edge</li> <li>1000b - ISF and interrupt when logic 0</li> <li>1001b - ISF and interrupt on rising edge</li> <li>1010b - ISF and interrupt on falling edge</li> <li>1011b - ISF and Interrupt on either edge</li> <li>1100b - ISF and interrupt when logic 1</li> <li>1101b - Enable active-high trigger output; ISF on rising edge (pin state is ORed with other enabled triggers to generate the output trigger for use by other peripherals)</li> <li>1110b - Enable active-low trigger output; ISF on falling edge (pin state is inverted and ORed with other enabled triggers to generate the output trigger for use by other peripherals)</li> <li>1111b - Reserved</li> </ul> |
| 15-0<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

### 12.7.1.13 Global Interrupt Control Low (GICLR)

#### Offset

| Register | Offset |
|----------|--------|
| GICLR    | 100h   |

#### Function

Updates any combination of the lower 16 Interrupt Control registers with the same value. This register supports only 32-bit writes and ignores any 16-bit or 8-bit writes.

#### Diagram

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

#### Fields

| Field         | Function                                                                                                                                                                                                             |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>GIWD | Global Interrupt Write Data<br>Indicates the write value that is written to the upper 16 bits of <a href="#">Interrupt Control a (ICR0 - ICR31)</a> , selected by GIWE.                                              |
| 15-0<br>GIWEn | Global Interrupt Write Enable<br>Indicates whether the upper 16 bits of the corresponding <a href="#">Interrupt Control a (ICR0 - ICR31)</a> are updated with the value in GIWD.<br>0b - Not updated<br>1b - Updated |

### 12.7.1.14 Global Interrupt Control High (GICHR)

#### Offset

| Register | Offset |
|----------|--------|
| GICHR    | 104h   |

**Function**

Updates any combination of the upper 16 Interrupt Control registers with the same value. This register supports only 32-bit writes and ignores any 16-bit or 8-bit writes.

**Diagram**

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

**Fields**

| Field | Function                                                                                                                                 |
|-------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | Global Interrupt Write Data                                                                                                              |
| GIWD  | Indicates the write value that is written to the upper 16 bits of <a href="#">Interrupt Control a (ICR0 - ICR31)</a> , selected by GIWE. |

  

| Field | Function                      |
|-------|-------------------------------|
| 15-0  | Global Interrupt Write Enable |

  

| Field | Function                                                                                                                                                                                 |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GIWEn | Indicates whether the upper 16 bits of the corresponding <a href="#">Interrupt Control a (ICR0 - ICR31)</a> are updated with the value in GIWD.<br><br>0b - Not updated.<br>1b - Updated |

**12.7.1.15 Interrupt Status Flag (ISFR0)****Offset**

| Register | Offset |
|----------|--------|
| ISFR0    | 120h   |

**Function**

Indicates whether the related configured interrupt is detected on each pin. The pin interrupt configuration is valid in all digital pin muxing modes. The ISF for each pin is also visible in the corresponding Interrupt Control register, and each flag can be cleared in either location.

**Diagram**

| Bits  | 31    | 30    | 29    | 28    | 27    | 26    | 25    | 24    | 23    | 22    | 21    | 20    | 19    | 18    | 17    | 16    |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| R     | ISF31 | ISF30 | ISF29 | ISF28 | ISF27 | ISF26 | ISF25 | ISF24 | ISF23 | ISF22 | ISF21 | ISF20 | ISF19 | ISF18 | ISF17 | ISF16 |
| W     | W1C   |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| Bits  | 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| R     | ISF15 | ISF14 | ISF13 | ISF12 | ISF11 | ISF10 | ISF9  | ISF8  | ISF7  | ISF6  | ISF5  | ISF4  | ISF3  | ISF2  | ISF1  | ISF0  |
| W     | W1C   |
| Reset | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

**Fields**

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>ISFn | <p>Interrupt Status Flag</p> <p>Indicates the detection of the configured interrupt on each pin of the same number. If this field is 0, the configured interrupt is not detected on the pin of the same number. If this field is 1, the configured interrupt is detected on the pin of the same number. If the pin is configured to generate a DMA request, then the corresponding flag is cleared automatically at the completion of the requested DMA transfer. Otherwise, the flag remains set until a logic 1 is written to the flag. If the pin is configured for a level-sensitive interrupt and the pin remains asserted, then the flag is set again immediately after it is cleared.</p> <p><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - Not detected</li> <li>1b - Detected</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul> |

# Chapter 13

## Input Multiplexing (INPUTMUX)

### 13.1 Chip-specific INPUTMUX information

Table 70. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | INPUTMUX       | <a href="#">INPUTMUX</a>            |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

Once set up, no clocks are required for the input multiplexer to function. The system clock is needed only to write to, or read from the INPUTMUX registers. Once the input multiplexer is configured, disable the clock to the INPUTMUX module in registers of the SYSCON module.

#### 13.1.1 Module instances

This device contains one instance of the INPUTMUX module.

### 13.2 Overview

The Input Multiplexing module (INPUTMUX) provides signal routing options for internal peripherals. Some peripheral inputs are multiplexed to multiple input sources. The sources can be external pins, interrupts, output signals of other peripherals, or other internal signals.

**NOTE**

Depending on the package, not all inputs from external pins may be available.

#### 13.2.1 Block Diagram

Figure 16 shows a generic input multiplexer arrangement with n inputs.



Figure 16. Generic input multiplexing

### 13.2.2 Features

- Configures the inputs to CMP, ADC, DAC, ENC, PWM, PWM EXT clock, AOI, external trigger.
- Configures the inputs to the Frequency Measurement (FREQME). This function is controlled by the FREQMECTRL register (See ANACTRL).

### 13.3 Functional description

The INPUTMUX implements a number of input multiplexers that select one of many inputs to be routed to a specific input signal for a given peripheral. This is used to allow user configuration of data paths between internal modules and/or external pins on the device. For every module input (output from the INPUTMUX), there is a register that selects the input to use, where the register name and description provide details on the module input controlled by each register. The input signal/pin options for each of the muxes are configurable, and can vary from mux to mux. Refer to the register descriptions for the details on the input signal/pin options used for each INPUTMUX output in [Memory map and register definition](#).

### 13.4 External signals

The INPUTMUX has no dedicated pins. Multiplexer inputs from external pins work independently of any other function assigned to the pin as long as no analog function is enabled.

Table 71. INPUTMUX pin description

| Pins                                                      | Peripheral               | Section       |
|-----------------------------------------------------------|--------------------------|---------------|
| Any existing pin on port 0 or 1                           | Pin interrupts 0 to 7    | See INPUTMUX. |
| PIO0_11, PIO0_12, PIO1_4                                  | Frequency measure module | See INPUTMUX. |
| SCT0_GPI [0:7] pin functions selected from IOCON register | SCTimer/PWM              | See SCTIMER.  |

## 13.5 Memory map and register definition

This section includes the INPUTMUX module memory map and detailed descriptions of all registers.

### 13.5.1 INPUTMUX register descriptions

#### 13.5.1.1 INPUTMUX memory map

INPUTMUX0 base address: 4000\_1000h

| Offset      | Register                                                              | Width<br>(In bits) | Access | Reset value |
|-------------|-----------------------------------------------------------------------|--------------------|--------|-------------|
| 20h - 2Ch   | Capture select register for CTIMER inputs (CTIMER0CAP0 - CTIMER0CAP3) | 32                 | RW     | 0000_007Fh  |
| 30h         | Trigger register for TIMER0 (TIMER0TRIG)                              | 32                 | RW     | 0000_007Fh  |
| 40h - 4Ch   | Capture select register for CTIMER inputs (CTIMER1CAP0 - CTIMER1CAP3) | 32                 | RW     | 0000_007Fh  |
| 50h         | Trigger register for TIMER1 (TIMER1TRIG)                              | 32                 | RW     | 0000_007Fh  |
| 60h - 6Ch   | Capture select register for CTIMER inputs (CTIMER2CAP0 - CTIMER2CAP3) | 32                 | RW     | 0000_007Fh  |
| 70h         | Trigger register for TIMER2 inputs (TIMER2TRIG)                       | 32                 | RW     | 0000_007Fh  |
| 180h        | Selection for frequency measurement reference clock (FREQMEAS_REF)    | 32                 | RW     | 0000_001Fh  |
| 184h        | Selection for frequency measurement reference clock (FREQMEAS_TAR)    | 32                 | RW     | 0000_001Fh  |
| 260h        | CMP0 input connections (CMP0_TRIG)                                    | 32                 | RW     | 0000_003Fh  |
| 280h - 28Ch | ADC Trigger input connections (ADC0_TRIGGER0 - ADC0_TRIGGER3)         | 32                 | RW     | 0000_003Fh  |
| 360h        | QDC0 Trigger Input Connections (QDC0_TRIGGER)                         | 32                 | RW     | 0000_003Fh  |
| 364h        | QDC0 Trigger Input Connections (QDC0_HOME)                            | 32                 | RW     | 0000_003Fh  |
| 368h        | QDC0 Trigger Input Connections (QDC0_INDEX)                           | 32                 | RW     | 0000_003Fh  |
| 36Ch        | QDC0 Trigger Input Connections (QDC0_PHASEB)                          | 32                 | RW     | 0000_003Fh  |
| 370h        | QDC0 Trigger Input Connections (QDC0_PHASEA)                          | 32                 | RW     | 0000_003Fh  |
| 374h        | QDC0 Trigger Input Connections (QDC0_ICAP1)                           | 32                 | RW     | 0000_003Fh  |
| 378h        | QDC0 Trigger Input Connections (QDC0_ICAP2)                           | 32                 | RW     | 0000_003Fh  |
| 37Ch        | QDC0 Trigger Input Connections (QDC0_ICAP3)                           | 32                 | RW     | 0000_003Fh  |
| 3A0h        | PWM0 input trigger connections (FlexPWM0_SM0_EXTA0)                   | 32                 | RW     | 0000_003Fh  |
| 3A4h        | PWM0 input trigger connections (FlexPWM0_SM0_EXTSYNC0)                | 32                 | RW     | 0000_003Fh  |
| 3A8h        | PWM0 input trigger connections (FlexPWM0_SM1_EXTAA1)                  | 32                 | RW     | 0000_003Fh  |
| 3ACh        | PWM0 input trigger connections (FlexPWM0_SM1_EXTSYNC1)                | 32                 | RW     | 0000_003Fh  |
| 3B0h        | PWM0 input trigger connections (FlexPWM0_SM2_EXTAA2)                  | 32                 | RW     | 0000_003Fh  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset      | Register                                                     | Width<br>(In bits) | Access | Reset value |
|-------------|--------------------------------------------------------------|--------------------|--------|-------------|
| 3B4h        | PWM0 input trigger connections (FlexPWM0_SM2_EXTSYNC2)       | 32                 | RW     | 0000_003Fh  |
| 3C0h        | PWM0 input trigger connections (FlexPWM0_FAULT0)             | 32                 | RW     | 0000_003Fh  |
| 3C4h        | PWM0 input trigger connections (FlexPWM0_FAULT1)             | 32                 | RW     | 0000_003Fh  |
| 3C8h        | PWM0 input trigger connections (FlexPWM0_FAULT2)             | 32                 | RW     | 0000_003Fh  |
| 3CCh        | PWM0 input trigger connections (FlexPWM0_FAULT3)             | 32                 | RW     | 0000_003Fh  |
| 3D0h        | PWM0 input trigger connections (FlexPWM0_FORCE)              | 32                 | RW     | 0000_003Fh  |
| 420h        | PWM0 external clock trigger (PWM0_EXT_CLK)                   | 32                 | RW     | 0000_0007h  |
| 440h - 47Ch | AOI0 trigger input connections 0-15 (AOI0_MUX0 - AOI0_MUX15) | 32                 | RW     | 0000_003Fh  |
| 480h        | USB-FS trigger input connections (USBFS_TRIG)                | 32                 | RW     | 0000_0007h  |
| 4C0h - 4D0h | EXT trigger connections 0-4 (EXT_TRIG0 - EXT_TRIG4)          | 32                 | RW     | 0000_001Fh  |
| 4D8h - 4DCh | EXT trigger connections 6-7 (EXT_TRIG6 - EXT_TRIG7)          | 32                 | RW     | 0000_001Fh  |
| 4E0h        | CMP1 input connections (CMP1_TRIG)                           | 32                 | RW     | 0000_003Fh  |
| 5A0h        | LPI2C0 trigger input connections (LPI2C0_TRIG)               | 32                 | RW     | 0000_003Fh  |
| 5E0h        | LPSPI0 trigger input connections (LPSPI0_TRIG)               | 32                 | RW     | 0000_003Fh  |
| 600h        | LPSPI1 trigger input connections (LPSPI1_TRIG)               | 32                 | RW     | 0000_003Fh  |
| 620h        | LPUART0 trigger input connections (LPUART0)                  | 32                 | RW     | 0000_003Fh  |
| 640h        | LPUART1 trigger input connections (LPUART1)                  | 32                 | RW     | 0000_003Fh  |
| 660h        | LPUART2 trigger input connections (LPUART2)                  | 32                 | RW     | 0000_003Fh  |

### 13.5.1.2 Capture select register for CTIMER inputs (CTIMER0CAP0 - CTIMER0CAP3)

#### Offset

| Register    | Offset |
|-------------|--------|
| CTIMER0CAP0 | 20h    |
| CTIMER0CAP1 | 24h    |
| CTIMER0CAP2 | 28h    |
| CTIMER0CAP3 | 2Ch    |

#### Function

For each of the 5 standard timers, numbered  $i = 0$  to  $4$  there are 4  $\text{TIMER}_i\text{CAP}_j$ , with  $j = 0$  to  $3$ , each allowing selecting between 25 external or internal input sources. The output of  $\text{TIMER}0\text{CAP}_0$  Input multiplexing register 0 selects the source for  $\text{TIMER}0$  capture input 0. The output of  $\text{TIMER}0\text{CAP}_1$  Input multiplexing register 1 selects the source for  $\text{TIMER}0$  capture input 1, and so forth up to  $\text{TIMER}4\text{CAP}_3$ . Input multiplexing register 3, which selects the input for  $\text{TIMER}4$  capture input 3.

**Diagram****Fields**

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-7<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6-0<br>INP | Input number for CTIMER0<br>000_0000b - Reserved<br>000_0001b - CT_INP0 input is selected<br>000_0010b - CT_INP1 input is selected<br>000_0011b - CT_INP2 input is selected<br>000_0100b - CT_INP3 input is selected<br>000_0101b - CT_INP4 input is selected<br>000_0110b - CT_INP5 input is selected<br>000_0111b - CT_INP6 input is selected<br>000_1000b - CT_INP7 input is selected<br>000_1001b - CT_INP8 input is selected<br>000_1010b - CT_INP9 input is selected<br>000_1011b - Reserved<br>000_1100b - Reserved<br>000_1101b - CT_INP12 input is selected<br>000_1110b - CT_INP13 input is selected<br>000_1111b - CT_INP14 input is selected<br>001_0000b - CT_INP15 input is selected<br>001_0001b - CT_INP16 input is selected<br>001_0010b - CT_INP17 input is selected<br>001_0011b - CT_INP18 input is selected |

Table continues on the next page...

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 001_0100b - CT_INP19 input is selected<br>001_0101b - USB0 usb0 start of frame input is selected<br>001_0110b - AOI0_OUT0 input is selected<br>001_0111b - AOI0_OUT1 input is selected<br>001_1000b - AOI0_OUT2 input is selected<br>001_1001b - AOI0_OUT3 input is selected<br>001_1010b - ADC0_tcomp[0] input is selected<br>001_1011b - ADC0_tcomp[1] input is selected<br>001_1100b - ADC0_tcomp[2] input is selected<br>001_1101b - ADC0_tcomp[3] input is selected<br>001_1110b - CMP0_OUT input is selected selected<br>001_1111b - CMP1_OUT input is selected selected<br>010_0000b - Reserved<br>010_0001b - CTimer1_MAT1 input is selected<br>010_0010b - CTimer1_MAT2 input is selected<br>010_0011b - CTimer1_MAT3 input is selected<br>010_0100b - CTimer2_MAT1 input is selected<br>010_0101b - CTimer2_MAT2 input is selected<br>010_0110b - CTimer2_MAT3 input is selected<br>010_0111b - QDC0_CMP_FLAG0 input input is selected<br>010_1000b - QDC0_CMP_FLAG1 input is selected<br>010_1001b - QDC0_CMP_FLAG2 input is selected<br>010_1010b - QDC0_CMP_FLAG3 input is selected<br>010_1011b - QDC0_POS_MATCH0 input is selected<br>010_1100b - PWM0_SM0_OUT_TRIG0 input is selected<br>010_1101b - PWM0_SM1_OUT_TRIG0 input is selected<br>010_1110b - PWM0_SM2_OUT_TRIG0 input is selected<br>010_1111b - Reserved<br>011_0000b - LPI2C0 Master End of Packet input is selected<br>011_0001b - LPI2C0 Slave End of Packet input is selected<br>011_0010b - Reserved<br>011_0011b - Reserved<br>011_0100b - LPSP10 End of Frame input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 011_0101b - LPSPI0 Received Data Word input is selected<br>011_0110b - LPSPI1 End of Frame input is selected<br>011_0111b - LPSPI1 Received Data Word input is selected<br>011_1000b - LPUART0 Received Data Word input is selected<br>011_1001b - LPUART0 Transmitted Data Word input is selected<br>011_1010b - LPUART0 Receive Line Idle input is selected<br>011_1011b - LPUART1 Received Data Word input is selected<br>011_1100b - LPUART1 Transmitted Data Word input is selected<br>011_1101b - LPUART1 Receive Line Idle input is selected<br>011_1110b - LPUART2 Received Data Word input is selected<br>011_1111b - LPUART2 Transmitted Data Word input is selected<br>100_0000b - LPUART2 Receive Line Idle input is selected<br>All other values are reserved. |

### 13.5.1.3 Trigger register for TIMER0 (TIMER0TRIG)

#### Offset

| Register   | Offset |
|------------|--------|
| TIMER0TRIG | 30h    |

#### Diagram



**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-7<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 6-0<br>INP | Input number for CTIMER0<br>000_0000b - Reserved<br>000_0001b - CT_INP0 input is selected<br>000_0010b - CT_INP1 input is selected<br>000_0011b - CT_INP2 input is selected<br>000_0100b - CT_INP3 input is selected<br>000_0101b - CT_INP4 input is selected<br>000_0110b - CT_INP5 input is selected<br>000_0111b - CT_INP6 input is selected<br>000_1000b - CT_INP7 input is selected<br>000_1001b - CT_INP8 input is selected<br>000_1010b - CT_INP9 input is selected<br>000_1011b - Reserved<br>000_1100b - Reserved<br>000_1101b - CT_INP12 input is selected<br>000_1110b - CT_INP13 input is selected<br>000_1111b - CT_INP14 input is selected<br>001_0000b - CT_INP15 input is selected<br>001_0001b - CT_INP16 input is selected<br>001_0010b - CT_INP17 input is selected<br>001_0011b - CT_INP18 input is selected<br>001_0100b - CT_INP19 input is selected<br>001_0101b - USB0 usb0 start of frame input is selected<br>001_0110b - AOI0_OUT0 input is selected<br>001_0111b - AOI0_OUT1 input is selected<br>001_1000b - AOI0_OUT2 input is selected<br>001_1001b - AOI0_OUT3 input is selected<br>001_1010b - ADC0_tcomp[0] input is selected<br>001_1011b - ADC0_tcomp[1] input is selected<br>001_1100b - ADC0_tcomp[2] input is selected<br>001_1101b - ADC0_tcomp[3] input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 001_1110b - CMP0_OUT input is selected selected<br>001_1111b - CMP1_OUT input is selected selected<br>010_0000b - Reserved<br>010_0001b - CTimer1_MAT1 input is selected<br>010_0010b - CTimer1_MAT2 input is selected<br>010_0011b - CTimer1_MAT3 input is selected<br>010_0100b - CTimer2_MAT1 input is selected<br>010_0101b - CTimer2_MAT2 input is selected<br>010_0110b - CTimer2_MAT3 input is selected<br>010_0111b - QDC0_CMP_FLAG0 input is selected<br>010_1000b - QDC0_CMP_FLAG1 input is selected<br>010_1001b - QDC0_CMP_FLAG2 input is selected<br>010_1010b - QDC0_CMP_FLAG3 input is selected<br>010_1011b - QDC0_POS_MATCH0 input is selected<br>010_1100b - PWM0_SM0_OUT_TRIG0 input is selected<br>010_1101b - PWM0_SM1_OUT_TRIG0 input is selected<br>010_1110b - PWM0_SM2_OUT_TRIG0 input is selected<br>010_1111b - Reserved<br>011_0000b - LPI2C0 Master End of Packet input is selected<br>011_0001b - LPI2C0 Slave End of Packet input is selected<br>011_0010b - Reserved<br>011_0011b - Reserved<br>011_0100b - LPSCI0 End of Frame input is selected<br>011_0101b - LPSCI0 Received Data Word input is selected<br>011_0110b - LPSCI1 End of Frame input is selected<br>011_0111b - LPSCI1 Received Data Word input is selected<br>011_1000b - LPUART0 Received Data Word input is selected<br>011_1001b - LPUART0 Transmitted Data Word input is selected<br>011_1010b - LPUART0 Receive Line Idle input is selected<br>011_1011b - LPUART1 Received Data Word input is selected<br>011_1100b - LPUART1 Transmitted Data Word input is selected<br>011_1101b - LPUART1 Receive Line Idle input is selected<br>011_1110b - LPUART2 Received Data Word input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                 |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 011_1111b - LPUART2 Transmitted Data Word input is selected<br>100_0000b - LPUART2 Receive Line Idle input is selected<br>All other values are reserved. |

### 13.5.1.4 Capture select register for CTIMER inputs (CTIMER1CAP0 - CTIMER1CAP3)

#### Offset

| Register    | Offset |
|-------------|--------|
| CTIMER1CAP0 | 40h    |
| CTIMER1CAP1 | 44h    |
| CTIMER1CAP2 | 48h    |
| CTIMER1CAP3 | 4Ch    |

#### Function

For each of the 5 standard timers, numbered i = 0 to 4 there are 4 TIMERiCAPTj, with j = 0 to 3, each allowing selecting between 25 external or internal input sources. The output of TIMER0CAPT0 Input multiplexing register 0 selects the source for TIMER0 capture input 0. The output of TIMER0CAPT1 Input multiplexing register 1 selects the source for TIMER0 capture input 1, and so forth up to TIMER4CAPT3. Input multiplexing register 3, which selects the input for TIMER4 capture input 3.

#### Diagram

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

#### Fields

| Field | Function |
|-------|----------|
| 31-7  | Reserved |
| —     |          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6-0<br>INP | Input number for CTIMER0<br>000_0000b - Reserved<br>000_0001b - CT_INP0 input is selected<br>000_0010b - CT_INP1 input is selected<br>000_0011b - CT_INP2 input is selected<br>000_0100b - CT_INP3 input is selected<br>000_0101b - CT_INP4 input is selected<br>000_0110b - CT_INP5 input is selected<br>000_0111b - CT_INP6 input is selected<br>000_1000b - CT_INP7 input is selected<br>000_1001b - CT_INP8 input is selected<br>000_1010b - CT_INP9 input is selected<br>000_1011b - Reserved<br>000_1100b - Reserved<br>000_1101b - CT_INP12 input is selected<br>000_1110b - CT_INP13 input is selected<br>000_1111b - CT_INP14 input is selected<br>001_0000b - CT_INP15 input is selected<br>001_0001b - CT_INP16 input is selected<br>001_0010b - CT_INP17 input is selected<br>001_0011b - CT_INP18 input is selected<br>001_0100b - CT_INP19 input is selected<br>001_0101b - USB0 usb0 start of frame input is selected<br>001_0110b - AOI0_OUT0 input is selected<br>001_0111b - AOI0_OUT1 input is selected<br>001_1000b - AOI0_OUT2 input is selected<br>001_1001b - AOI0_OUT3 input is selected<br>001_1010b - ADC0_tcomp[0] input is selected<br>001_1011b - ADC0_tcomp[1] input is selected<br>001_1100b - ADC0_tcomp[2] input is selected<br>001_1101b - ADC0_tcomp[3] input is selected<br>001_1110b - CMP0_OUT input is selected<br>001_1111b - CMP1_OUT input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 010_0000b - Reserved<br>010_0001b - CTimer0_MAT1 input is selected<br>010_0010b - CTimer0_MAT2 input is selected<br>010_0011b - CTimer0_MAT3 input is selected<br>010_0100b - CTimer2_MAT1 input is selected<br>010_0101b - CTimer2_MAT2 input is selected<br>010_0110b - CTimer2_MAT3 input is selected<br>010_0111b - QDC0_CMP_FLAG0 input is selected<br>010_1000b - QDC0_CMP_FLAG1 input is selected<br>010_1001b - QDC0_CMP_FLAG2 input is selected<br>010_1010b - QDC0_CMP_FLAG3 input is selected<br>010_1011b - QDC0_POS_MATCH0 input is selected<br>010_1100b - PWM0_SM0_OUT_TRIG0 input is selected<br>010_1101b - PWM0_SM1_OUT_TRIG0 input is selected<br>010_1110b - PWM0_SM2_OUT_TRIG0 input is selected<br>010_1111b - Reserved<br>011_0000b - LPI2C0 Master End of Packet input is selected<br>011_0001b - LPI2C0 Slave End of Packet input is selected<br>011_0010b - Reserved<br>011_0011b - Reserved<br>011_0100b - LPSPI0 End of Frame input is selected<br>011_0101b - LPSPI0 Received Data Word input is selected<br>011_0110b - LPSPI1 End of Frame input is selected<br>011_0111b - LPSPI1 Received Data Word input is selected<br>011_1000b - LPUART0 Received Data Word input is selected<br>011_1001b - LPUART0 Transmitted Data Word input is selected<br>011_1010b - LPUART0 Receive Line Idle input is selected<br>011_1011b - LPUART1 Received Data Word input is selected<br>011_1100b - LPUART1 Transmitted Data Word input is selected<br>011_1101b - LPUART1 Receive Line Idle input is selected<br>011_1110b - LPUART2 Received Data Word input is selected<br>011_1111b - LPUART2 Transmitted Data Word input is selected<br>100_0000b - LPUART2 Receive Line Idle input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                       |
|-------|--------------------------------|
|       | All other values are reserved. |

### 13.5.1.5 Trigger register for TIMER1 (TIMER1TRIG)

#### Offset

| Register   | Offset |
|------------|--------|
| TIMER1TRIG | 50h    |

#### Diagram



#### Fields

| Field      | Function                                                                                                                                                                                                                                                                                                                                        |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-7<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                        |
| 6-0<br>INP | Input number for CTIMER0<br>000_0000b - Reserved<br>000_0001b - CT_INP0 input is selected<br>000_0010b - CT_INP1 input is selected<br>000_0011b - CT_INP2 input is selected<br>000_0100b - CT_INP3 input is selected<br>000_0101b - CT_INP4 input is selected<br>000_0110b - CT_INP5 input is selected<br>000_0111b - CT_INP6 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 000_1000b - CT_INP7 input is selected<br>000_1001b - CT_INP8 input is selected<br>000_1010b - CT_INP9 input is selected<br>000_1011b - Reserved<br>000_1100b - Reserved<br>000_1101b - CT_INP12 input is selected<br>000_1110b - CT_INP13 input is selected<br>000_1111b - CT_INP14 input is selected<br>001_0000b - CT_INP15 input is selected<br>001_0001b - CT_INP16 input is selected<br>001_0010b - CT_INP17 input is selected<br>001_0011b - CT_INP18 input is selected<br>001_0100b - CT_INP19 input is selected<br>001_0101b - USB0 usb0 start of frame input is selected<br>001_0110b - AOI0_OUT0 input is selected<br>001_0111b - AOI0_OUT1 input is selected<br>001_1000b - AOI0_OUT2 input is selected<br>001_1001b - AOI0_OUT3 input is selected<br>001_1010b - ADC0_tcomp[0] input is selected<br>001_1011b - ADC0_tcomp[1] input is selected<br>001_1100b - ADC0_tcomp[2] input is selected<br>001_1101b - ADC0_tcomp[3] input is selected<br>001_1110b - CMP0_OUT input is selected<br>001_1111b - CMP1_OUT input is selected<br>010_0000b - Reserved<br>010_0001b - CTimer0_MAT1 input is selected<br>010_0010b - CTimer0_MAT2 input is selected<br>010_0011b - CTimer0_MAT3 input is selected<br>010_0100b - CTimer2_MAT1 input is selected<br>010_0101b - CTimer2_MAT2 input is selected<br>010_0110b - CTimer2_MAT3 input is selected<br>010_0111b - QDC0_CMP_FLAG0 input is selected<br>010_1000b - QDC0_CMP_FLAG1 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 010_1001b - QDC0_CMP_FLAG2 input is selected<br>010_1010b - QDC0_CMP_FLAG3 input is selected<br>010_1011b - QDC0_POS_MATCH0 input is selected<br>010_1100b - PWM0_SM0_OUT_TRIG0 input is selected<br>010_1101b - PWM0_SM1_OUT_TRIG0 input is selected<br>010_1110b - PWM0_SM2_OUT_TRIG0 input is selected<br>010_1111b - Reserved<br>011_0000b - LPI2C0 Master End of Packet input is selected<br>011_0001b - LPI2C0 Slave End of Packet input is selected<br>011_0010b - Reserved<br>011_0011b - Reserved<br>011_0100b - LPSPSI0 End of Frame input is selected<br>011_0101b - LPSPSI0 Received Data Word input is selected<br>011_0110b - LPSPSI1 End of Frame input is selected<br>011_0111b - LPSPSI1 Received Data Word input is selected<br>011_1000b - LPUART0 Received Data Word input is selected<br>011_1001b - LPUART0 Transmitted Data Word input is selected<br>011_1010b - LPUART0 Receive Line Idle input is selected<br>011_1011b - LPUART1 Received Data Word input is selected<br>011_1100b - LPUART1 Transmitted Data Word input is selected<br>011_1101b - LPUART1 Receive Line Idle input is selected<br>011_1110b - LPUART2 Received Data Word input is selected<br>011_1111b - LPUART2 Transmitted Data Word input is selected<br>100_0000b - LPUART2 Receive Line Idle input is selected<br>All other values are reserved. |

### 13.5.1.6 Capture select register for CTIMER inputs (CTIMER2CAP0 - CTIMER2CAP3)

#### Offset

| Register    | Offset |
|-------------|--------|
| CTIMER2CAP0 | 60h    |
| CTIMER2CAP1 | 64h    |
| CTIMER2CAP2 | 68h    |
| CTIMER2CAP3 | 6Ch    |

**Function**

For each of the 5 standard timers, numbered  $i = 0$  to  $4$  there are 4 TIMER*i*CAPT $j$ , with  $j = 0$  to  $3$ , each allowing selecting between 25 external or internal input sources. The output of TIMER0CAPT0 Input multiplexing register 0 selects the source for TIMER0 capture input 0. The output of TIMER0CAPT1 Input multiplexing register 1 selects the source for TIMER0 capture input 1, and so forth up to TIMER4CAPT3. Input multiplexing register 3, which selects the input for TIMER4 capture input 3.

**Diagram**

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

**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-7<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 6-0<br>INP | Input number for CTIMER0<br>000_0000b - Reserved<br>000_0001b - CT_INP0 input is selected<br>000_0010b - CT_INP1 input is selected<br>000_0011b - CT_INP2 input is selected<br>000_0100b - CT_INP3 input is selected<br>000_0101b - CT_INP4 input is selected<br>000_0110b - CT_INP5 input is selected<br>000_0111b - CT_INP6 input is selected<br>000_1000b - CT_INP7 input is selected<br>000_1001b - CT_INP8 input is selected<br>000_1010b - CT_INP9 input is selected<br>000_1011b - Reserved<br>000_1100b - Reserved<br>000_1101b - CT_INP12 input is selected<br>000_1110b - CT_INP13 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 000_1111b - CT_INP14 input is selected<br>001_0000b - CT_INP15 input is selected<br>001_0001b - CT_INP16 input is selected<br>001_0010b - CT_INP17 input is selected<br>001_0011b - CT_INP18 input is selected<br>001_0100b - CT_INP19 input is selected<br>001_0101b - USB0 usb0 start of frame input is selected<br>001_0110b - AOI0_OUT0 input is selected<br>001_0111b - AOI0_OUT1 input is selected<br>001_1000b - AOI0_OUT2 input is selected<br>001_1001b - AOI0_OUT3 input is selected<br>001_1010b - ADC0_tcomp[0] input is selected<br>001_1011b - ADC0_tcomp[1] input is selected<br>001_1100b - ADC0_tcomp[2] input is selected<br>001_1101b - ADC0_tcomp[3] input is selected<br>001_1110b - CMP0_OUT input is selected<br>001_1111b - CMP1_OUT input is selected<br>010_0000b - Reserved<br>010_0001b - CTimer0_MAT1 input is selected<br>010_0010b - CTimer0_MAT2 input is selected<br>010_0011b - CTimer0_MAT3 input is selected<br>010_0100b - CTimer1_MAT1 input is selected<br>010_0101b - CTimer1_MAT2 input is selected<br>010_0110b - CTimer1_MAT3 input is selected<br>010_0111b - QDC0_CMP_FLAG0 input is selected<br>010_1000b - QDC0_CMP_FLAG1 input is selected<br>010_1001b - QDC0_CMP_FLAG2 input is selected<br>010_1010b - QDC0_CMP_FLAG3 input is selected<br>010_1011b - QDC0_POS_MATCH0 input is selected<br>010_1100b - PWM0_SM0_OUT_TRIG0 input is selected<br>010_1101b - PWM0_SM1_OUT_TRIG0 input is selected<br>010_1110b - PWM0_SM2_OUT_TRIG0 input is selected<br>010_1111b - Reserved |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 011_0000b - LPI2C0 Master End of Packet input is selected<br>011_0001b - LPI2C0 Slave End of Packet input is selected<br>011_0010b - Reserved<br>011_0011b - Reserved<br>011_0100b - LPSP10 End of Frame input is selected<br>011_0101b - LPSP10 Received Data Word input is selected<br>011_0110b - LPSP11 End of Frame input is selected<br>011_0111b - LPSP11 Received Data Word input is selected<br>011_1000b - LPUART0 Received Data Word input is selected<br>011_1001b - LPUART0 Transmitted Data Word input is selected<br>011_1010b - LPUART0 Receive Line Idle input is selected<br>011_1011b - LPUART1 Received Data Word input is selected<br>011_1100b - LPUART1 Transmitted Data Word input is selected<br>011_1101b - LPUART1 Receive Line Idle input is selected<br>011_1110b - LPUART2 Received Data Word input is selected<br>011_1111b - LPUART2 Transmitted Data Word input is selected<br>100_0000b - LPUART2 Receive Line Idle input is selected<br>All other values are reserved. |

### 13.5.1.7 Trigger register for TIMER2 inputs (TIMER2TRIG)

#### Offset

| Register   | Offset |
|------------|--------|
| TIMER2TRIG | 70h    |

#### Diagram

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

**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-7<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 6-0<br>INP | Input number for CTIMER0<br>000_0000b - Reserved<br>000_0001b - CT_INP0 input is selected<br>000_0010b - CT_INP1 input is selected<br>000_0011b - CT_INP2 input is selected<br>000_0100b - CT_INP3 input is selected<br>000_0101b - CT_INP4 input is selected<br>000_0110b - CT_INP5 input is selected<br>000_0111b - CT_INP6 input is selected<br>000_1000b - CT_INP7 input is selected<br>000_1001b - CT_INP8 input is selected<br>000_1010b - CT_INP9 input is selected<br>000_1011b - Reserved<br>000_1100b - Reserved<br>000_1101b - CT_INP12 input is selected<br>000_1110b - CT_INP13 input is selected<br>000_1111b - CT_INP14 input is selected<br>001_0000b - CT_INP15 input is selected<br>001_0001b - CT_INP16 input is selected<br>001_0010b - CT_INP17 input is selected<br>001_0011b - CT_INP18 input is selected<br>001_0100b - CT_INP19 input is selected<br>001_0101b - USB0 usb0 start of frame input is selected<br>001_0110b - AOI0_OUT0 input is selected<br>001_0111b - AOI0_OUT1 input is selected<br>001_1000b - AOI0_OUT2 input is selected<br>001_1001b - AOI0_OUT3 input is selected<br>001_1010b - ADC0_tcomp[0] input is selected<br>001_1011b - ADC0_tcomp[1] input is selected<br>001_1100b - ADC0_tcomp[2] input is selected<br>001_1101b - ADC0_tcomp[3] input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 001_1110b - CMP0_OUT input is selected selected<br>001_1111b - CMP1_OUT input is selected selected<br>010_0000b - Reserved<br>010_0001b - CTimer0_MAT1 input is selected<br>010_0010b - CTimer0_MAT2 input is selected<br>010_0011b - CTimer0_MAT3 input is selected<br>010_0100b - CTimer1_MAT1 input is selected<br>010_0101b - CTimer1_MAT2 input is selected<br>010_0110b - CTimer1_MAT3 input is selected<br>010_0111b - QDC0_CMP_FLAG0 input is selected<br>010_1000b - QDC0_CMP_FLAG1 input is selected<br>010_1001b - QDC0_CMP_FLAG2 input is selected<br>010_1010b - QDC0_CMP_FLAG3 input is selected<br>010_1011b - QDC0_POS_MATCH0 input is selected<br>010_1100b - PWM0_SM0_OUT_TRIG0 input is selected<br>010_1101b - PWM0_SM1_OUT_TRIG0 input is selected<br>010_1110b - PWM0_SM2_OUT_TRIG0 input is selected<br>010_1111b - Reserved<br>011_0000b - LPI2C0 Master End of Packet input is selected<br>011_0001b - LPI2C0 Slave End of Packet input is selected<br>011_0010b - Reserved<br>011_0011b - Reserved<br>011_0100b - LPSCI0 End of Frame input is selected<br>011_0101b - LPSCI0 Received Data Word input is selected<br>011_0110b - LPSCI1 End of Frame input is selected<br>011_0111b - LPSCI1 Received Data Word input is selected<br>011_1000b - LPUART0 Received Data Word input is selected<br>011_1001b - LPUART0 Transmitted Data Word input is selected<br>011_1010b - LPUART0 Receive Line Idle input is selected<br>011_1011b - LPUART1 Received Data Word input is selected<br>011_1100b - LPUART1 Transmitted Data Word input is selected<br>011_1101b - LPUART1 Receive Line Idle input is selected<br>011_1110b - LPUART2 Received Data Word input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                 |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 011_1111b - LPUART2 Transmitted Data Word input is selected<br>100_0000b - LPUART2 Receive Line Idle input is selected<br>All other values are reserved. |

### 13.5.1.8 Selection for frequency measurement reference clock (FREQMEAS\_REF)

#### Offset

| Register     | Offset |
|--------------|--------|
| FREQMEAS_REF | 180h   |

#### Function

This register selects a clock for the reference clock of the frequency measure function. By default, no clock is selected.

#### Diagram



#### Fields

| Field      | Function                                                                                                                                                                                                                         |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-5       | Reserved                                                                                                                                                                                                                         |
| 4-0<br>INP | Clock source number (binary value) for frequency measure function target clock.<br>0_0000b - Reserved<br>0_0001b - clk_in input is selected<br>0_0010b - FRO_OSC_12M input is selected<br>0_0011b - fro_hf_div input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 0_0100b - Reserved<br>0_0101b - clk_16k[1] input is selected<br>0_0110b - SLOW_CLK input is selected<br>0_0111b - FREQME_CLK_IN0 input is selected<br>0_1000b - FREQME_CLK_IN1 input is selected<br>0_1001b - AOI0_OUT0 input is selected<br>0_1010b - AOI0_OUT1 input is selected<br>0_1011b - PWM0_SM0_OUT_TRIG0 input is selected<br>0_1100b - PWM0_SM0_OUT_TRIG1 input is selected<br>0_1101b - PWM0_SM1_OUT_TRIG0 input is selected<br>0_1110b - PWM0_SM1_OUT_TRIG1 input is selected<br>0_1111b - PWM0_SM2_OUT_TRIG0 input is selected<br>1_0000b - PWM0_SM2_OUT_TRIG1 input is selected<br>All other values are reserved. |

### 13.5.1.9 Selection for frequency measurement reference clock (FREQMEAS\_TAR)

#### Offset

| Register     | Offset |
|--------------|--------|
| FREQMEAS_TAR | 184h   |

#### Function

This register selects a clock for the target clock of the frequency measure function. By default, no clock is selected.

#### Diagram



**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-5<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 4-0<br>INP | Clock source number (binary value) for frequency measure function target clock.<br>0_0000b - Reserved<br>0_0001b - clk_in input is selected<br>0_0010b - FRO_OSC_12M input is selected<br>0_0011b - fro_hf_div input is selected<br>0_0100b - Reserved<br>0_0101b - clk_16k[1] input is selected<br>0_0110b - SLOW_CLK input is selected<br>0_0111b - FREQME_CLK_IN0 input is selected<br>0_1000b - FREQME_CLK_IN1 input is selected<br>0_1001b - AOI0_OUT0 input is selected<br>0_1010b - AOI0_OUT1 input is selected<br>0_1011b - PWM0_SM0_OUT_TRIG0 input is selected<br>0_1100b - PWM0_SM0_OUT_TRIG1 input is selected<br>0_1101b - PWM0_SM1_OUT_TRIG0 input is selected<br>0_1110b - PWM0_SM1_OUT_TRIG1 input is selected<br>0_1111b - PWM0_SM2_OUT_TRIG0 input is selected<br>1_0000b - PWM0_SM2_OUT_TRIG1 input is selected<br>All other values are reserved. |

**13.5.1.10 CMP0 input connections (CMP0\_TRIG)****Offset**

| Register  | Offset |
|-----------|--------|
| CMP0_TRIG | 260h   |

**Function**

This register selects the CMP0 trigger inputs.

**Diagram****Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5-0<br>TRIGIN | CMP0 input trigger<br>00_0000b - Reserved<br>00_0001b - ARM_TXEV input is selected<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP1_OUT input is selected<br>00_0111b - Reserved<br>00_1000b - CTimer0_MAT0 input is selected<br>00_1001b - CTimer0_MAT2 input is selected<br>00_1010b - CTimer1_MAT0 input is selected<br>00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer2_MAT0 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - LPTMR0 input is selected<br>00_1111b - Reserved<br>01_0000b - QDC0_POS_MATCH0<br>01_0001b - PWM0_SM0_OUT_TRIG0 input is selected<br>01_0010b - PWM0_SM0_OUT_TRIG1 input is selected<br>01_0011b - PWM0_SM1_OUT_TRIG0 input is selected |

Table continues on the next page...

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 01_0100b - PWM0_SM1_OUT_TRIG1 input is selected<br>01_0101b - PWM0_SM2_OUT_TRIG0 input is selected<br>01_0110b - PWM0_SM2_OUT_TRIG1 input is selected<br>01_0111b - Reserved<br>01_1000b - Reserved<br>01_1001b - GPIO0 Pin Event Trig 0 input is selected<br>01_1010b - GPIO1 Pin Event Trig 0 input is selected<br>01_1011b - GPIO2 Pin Event Trig 0 input is selected<br>01_1100b - GPIO3 Pin Event Trig 0 input is selected<br>01_1101b - Reserved<br>01_1110b - WUU input is selected<br>All other values are reserved. |

### 13.5.1.11 ADC Trigger input connections (ADC0\_TRIG0 - ADC0\_TRIG3)

#### Offset

| Register   | Offset |
|------------|--------|
| ADC0_TRIG0 | 280h   |
| ADC0_TRIG1 | 284h   |
| ADC0_TRIG2 | 288h   |
| ADC0_TRIG3 | 28Ch   |

#### Function

This register selects the ADC trigger inputs.

#### Diagram



**Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5-0<br>TRIGIN | ADC0 trigger inputs<br>00_0000b - Reserved<br>00_0001b - ARM_TXEV input is selected<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT0 input is selected<br>00_1010b - CTimer0_MAT1 input is selected<br>00_1011b - CTimer1_MAT0 input is selected<br>00_1100b - CTimer1_MAT1 input is selected<br>00_1101b - CTimer2_MAT0 input is selected<br>00_1110b - CTimer2_MAT1 input is selected<br>00_1111b - LPTMR0 input is selected<br>01_0000b - Reserved<br>01_0001b - QDC0_POS_MATCH0 input is selected<br>01_0010b - PWM0_SM0_OUT_TRIG0 input is selected<br>01_0011b - PWM0_SM0_OUT_TRIG1 input is selected<br>01_0100b - PWM0_SM1_OUT_TRIG0 input is selected<br>01_0101b - PWM0_SM1_OUT_TRIG1 input is selected<br>01_0110b - PWM0_SM2_OUT_TRIG0 input is selected<br>01_0111b - PWM0_SM2_OUT_TRIG1 input is selected<br>01_1000b - Reserved<br>01_1001b - Reserved<br>01_1010b - GPIO0 Pin Event Trig 0 input is selected<br>01_1011b - GPIO1 Pin Event Trig 0 input is selected<br>01_1100b - GPIO2 Pin Event Trig 0 input is selected<br>01_1101b - GPIO3 Pin Event Trig 0 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                |
|-------|-------------------------------------------------------------------------|
|       | 01_1110b - Reserved<br>01_1111b - WUU<br>All other values are reserved. |

### 13.5.1.12 QDC0 Trigger Input Connections (QDC0\_TRIG)

#### Offset

| Register  | Offset |
|-----------|--------|
| QDC0_TRIG | 360h   |

#### Function

This register selects the QDC0 trigger inputs.

#### Diagram

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

#### Fields

| Field      | Function                                                                                                                                                                   |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—  | Reserved                                                                                                                                                                   |
| 5-0<br>INP | QDC0 input connections<br>00_0000b - Reserved<br>00_0001b - ARM_TXEV input is selected<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT2 input is selected<br>00_1010b - CTimer0_MAT3 input is selected<br>00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer1_MAT3 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - CTimer2_MAT3 input is selected<br>00_1111b - QDC0_POS_MATCH0 input is selected<br>01_0000b - PWM0_SM0_OUT_TRIG0 input is selected<br>01_0001b - PWM0_SM0_OUT_TRIG1 input is selected<br>01_0010b - PWM0_SM1_OUT_TRIG0 input is selected<br>01_0011b - PWM0_SM1_OUT_TRIG1 input is selected<br>01_0100b - PWM0_SM2_OUT_TRIG0 input is selected<br>01_0101b - PWM0_SM2_OUT_TRIG1 input is selected<br>01_0110b - Reserved<br>01_0111b - Reserved<br>01_1000b - TRIG_IN0 input is selected<br>01_1001b - TRIG_IN1 input is selected<br>01_1010b - TRIG_IN2 input is selected<br>01_1011b - TRIG_IN3 input is selected<br>01_1100b - TRIG_IN4 input is selected<br>01_1101b - TRIG_IN5 input is selected<br>01_1110b - TRIG_IN6 input is selected<br>01_1111b - TRIG_IN7 input is selected<br>10_0000b - TRIG_IN8 input is selected<br>10_0001b - TRIG_IN9 input is selected<br>10_0010b - TRIG_IN10 input is selected<br>10_0011b - TRIG_IN11 input is selected<br>10_0100b - GPIO0 Pin Event Trig 0 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                            |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 10_0101b - GPIO1 Pin Event Trig 0 input is selected<br>10_0110b - GPIO2 Pin Event Trig 0 input is selected<br>10_0111b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.13 QDC0 Trigger Input Connections (QDC0\_HOME)

#### Offset

| Register  | Offset |
|-----------|--------|
| QDC0_HOME | 364h   |

#### Function

This register selects the QDC0 trigger inputs.

#### Diagram



#### Fields

| Field      | Function                                                                                                                         |
|------------|----------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—  | Reserved                                                                                                                         |
| 5-0<br>INP | QDC0 input connections<br>00_0000b - Reserved<br>00_0001b - ARM_TXEV input is selected<br>00_0010b - AOI0_OUT0 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT2 input is selected<br>00_1010b - CTimer0_MAT3 input is selected<br>00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer1_MAT3 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - CTimer2_MAT3 input is selected<br>00_1111b - QDC0_POS_MATCH0 input is selected<br>01_0000b - PWM0_SM0_OUT_TRIG0 input is selected<br>01_0001b - PWM0_SM0_OUT_TRIG1 input is selected<br>01_0010b - PWM0_SM1_OUT_TRIG0 input is selected<br>01_0011b - PWM0_SM1_OUT_TRIG1 input is selected<br>01_0100b - PWM0_SM2_OUT_TRIG0 input is selected<br>01_0101b - PWM0_SM2_OUT_TRIG1 input is selected<br>01_0110b - Reserved<br>01_0111b - Reserved<br>01_1000b - TRIG_IN0 input is selected<br>01_1001b - TRIG_IN1 input is selected<br>01_1010b - TRIG_IN2 input is selected<br>01_1011b - TRIG_IN3 input is selected<br>01_1100b - TRIG_IN4 input is selected<br>01_1101b - TRIG_IN5 input is selected<br>01_1110b - TRIG_IN6 input is selected<br>01_1111b - TRIG_IN7 input is selected<br>10_0000b - TRIG_IN8 input is selected<br>10_0001b - TRIG_IN9 input is selected<br>10_0010b - TRIG_IN10 input is selected<br>10_0011b - TRIG_IN11 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                   |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 10_0100b - GPIO0 Pin Event Trig 0 input is selected<br>10_0101b - GPIO1 Pin Event Trig 0 input is selected<br>10_0110b - GPIO2 Pin Event Trig 0 input is selected<br>10_0111b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.14 QDC0 Trigger Input Connections (QDC0\_INDEX)

#### Offset

| Register   | Offset |
|------------|--------|
| QDC0_INDEX | 368h   |

#### Function

This register selects the QDC0 trigger inputs.

#### Diagram



#### Fields

| Field      | Function                                                                               |
|------------|----------------------------------------------------------------------------------------|
| 31-6       | Reserved                                                                               |
| 5-0<br>INP | QDC0 input connections<br>00_0000b - Reserved<br>00_0001b - ARM_TXEV input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT2 input is selected<br>00_1010b - CTimer0_MAT3 input is selected<br>00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer1_MAT3 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - CTimer2_MAT3 input is selected<br>00_1111b - QDC0_POS_MATCH0 input is selected<br>01_0000b - PWM0_SM0_OUT_TRIG0 input is selected<br>01_0001b - PWM0_SM0_OUT_TRIG1 input is selected<br>01_0010b - PWM0_SM1_OUT_TRIG0 input is selected<br>01_0011b - PWM0_SM1_OUT_TRIG1 input is selected<br>01_0100b - PWM0_SM2_OUT_TRIG0 input is selected<br>01_0101b - PWM0_SM2_OUT_TRIG1 input is selected<br>01_0110b - Reserved<br>01_0111b - Reserved<br>01_1000b - TRIG_IN0 input is selected<br>01_1001b - TRIG_IN1 input is selected<br>01_1010b - TRIG_IN2 input is selected<br>01_1011b - TRIG_IN3 input is selected<br>01_1100b - TRIG_IN4 input is selected<br>01_1101b - TRIG_IN5 input is selected<br>01_1110b - TRIG_IN6 input is selected<br>01_1111b - TRIG_IN7 input is selected<br>10_0000b - TRIG_IN8 input is selected<br>10_0001b - TRIG_IN9 input is selected<br>10_0010b - TRIG_IN10 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                             |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 10_0011b - TRIG_IN11 input is selected<br>10_0100b - GPIO0 Pin Event Trig 0 input is selected<br>10_0101b - GPIO1 Pin Event Trig 0 input is selected<br>10_0110b - GPIO2 Pin Event Trig 0 input is selected<br>10_0111b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.15 QDC0 Trigger Input Connections (QDC0\_PHASEB)

#### Offset

| Register    | Offset |
|-------------|--------|
| QDC0_PHASEB | 36Ch   |

#### Function

This register selects the QDC0 trigger inputs.

#### Diagram



#### Fields

| Field | Function               |
|-------|------------------------|
| 31-6  | Reserved               |
| —     |                        |
| 5-0   | QDC0 input connections |
| INP   | 00_0000b - Reserved    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 00_0001b - ARM_TXEV input is selected<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT2 input is selected<br>00_1010b - CTimer0_MAT3 input is selected<br>00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer1_MAT3 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - CTimer2_MAT3 input is selected<br>00_1111b - QDC0_POS_MATCH0 input is selected<br>01_0000b - PWM0_SM0_OUT_TRIG0 input is selected<br>01_0001b - PWM0_SM0_OUT_TRIG1 input is selected<br>01_0010b - PWM0_SM1_OUT_TRIG0 input is selected<br>01_0011b - PWM0_SM1_OUT_TRIG1 input is selected<br>01_0100b - PWM0_SM2_OUT_TRIG0 input is selected<br>01_0101b - PWM0_SM2_OUT_TRIG1 input is selected<br>01_0110b - Reserved<br>01_0111b - Reserved<br>01_1000b - TRIG_IN0 input is selected<br>01_1001b - TRIG_IN1 input is selected<br>01_1010b - TRIG_IN2 input is selected<br>01_1011b - TRIG_IN3 input is selected<br>01_1100b - TRIG_IN4 input is selected<br>01_1101b - TRIG_IN5 input is selected<br>01_1110b - TRIG_IN6 input is selected<br>01_1111b - TRIG_IN7 input is selected<br>10_0000b - TRIG_IN8 input is selected<br>10_0001b - TRIG_IN9 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                       |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 10_0010b - TRIG_IN10 input is selected<br>10_0011b - TRIG_IN11 input is selected<br>10_0100b - GPIO0 Pin Event Trig 0 input is selected<br>10_0101b - GPIO1 Pin Event Trig 0 input is selected<br>10_0110b - GPIO2 Pin Event Trig 0 input is selected<br>10_0111b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.16 QDC0 Trigger Input Connections (QDC0\_PHASEA)

#### Offset

| Register    | Offset |
|-------------|--------|
| QDC0_PHASEA | 370h   |

#### Function

This register selects the QDC0 trigger inputs.

#### Diagram



#### Fields

| Field      | Function               |
|------------|------------------------|
| 31-6<br>—  | Reserved               |
| 5-0<br>INP | QDC0 input connections |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 00_0000b - Reserved<br>00_0001b - ARM_TXEV input is selected<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT2 input is selected<br>00_1010b - CTimer0_MAT3 input is selected<br>00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer1_MAT3 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - CTimer2_MAT3 input is selected<br>00_1111b - QDC0_POS_MATCH0 input is selected<br>01_0000b - PWM0_SM0_OUT_TRIG0 input is selected<br>01_0001b - PWM0_SM0_OUT_TRIG1 input is selected<br>01_0010b - PWM0_SM1_OUT_TRIG0 input is selected<br>01_0011b - PWM0_SM1_OUT_TRIG1 input is selected<br>01_0100b - PWM0_SM2_OUT_TRIG0 input is selected<br>01_0101b - PWM0_SM2_OUT_TRIG1 input is selected<br>01_0110b - Reserved<br>01_0111b - Reserved<br>01_1000b - TRIG_IN0 input is selected<br>01_1001b - TRIG_IN1 input is selected<br>01_1010b - TRIG_IN2 input is selected<br>01_1011b - TRIG_IN3 input is selected<br>01_1100b - TRIG_IN4 input is selected<br>01_1101b - TRIG_IN5 input is selected<br>01_1110b - TRIG_IN6 input is selected<br>01_1111b - TRIG_IN7 input is selected<br>10_0000b - TRIG_IN8 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 10_0001b - TRIG_IN9 input is selected<br>10_0010b - TRIG_IN10 input is selected<br>10_0011b - TRIG_IN11 input is selected<br>10_0100b - GPIO0 Pin Event Trig 0 input is selected<br>10_0101b - GPIO1 Pin Event Trig 0 input is selected<br>10_0110b - GPIO2 Pin Event Trig 0 input is selected<br>10_0111b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.17 QDC0 Trigger Input Connections (QDC0\_ICAP1)

#### Offset

| Register   | Offset |
|------------|--------|
| QDC0_ICAP1 | 374h   |

#### Function

This register selects the QDC0 trigger inputs.

#### Diagram



#### Fields

| Field | Function               |
|-------|------------------------|
| 31-6  | Reserved               |
| —     |                        |
| 5-0   | QDC0 input connections |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INP   | 00_0000b - Reserved<br>00_0001b - ARM_TXEV input is selected<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT2 input is selected<br>00_1010b - CTimer0_MAT3 input is selected<br>00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer1_MAT3 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - CTimer2_MAT3 input is selected<br>00_1111b - QDC0_POS_MATCH0 input is selected<br>01_0000b - PWM0_SM0_OUT_TRIG0 input is selected<br>01_0001b - PWM0_SM0_OUT_TRIG1 input is selected<br>01_0010b - PWM0_SM1_OUT_TRIG0 input is selected<br>01_0011b - PWM0_SM1_OUT_TRIG1 input is selected<br>01_0100b - PWM0_SM2_OUT_TRIG0 input is selected<br>01_0101b - PWM0_SM2_OUT_TRIG1 input is selected<br>01_0110b - Reserved<br>01_0111b - Reserved<br>01_1000b - TRIG_IN0 input is selected<br>01_1001b - TRIG_IN1 input is selected<br>01_1010b - TRIG_IN2 input is selected<br>01_1011b - TRIG_IN3 input is selected<br>01_1100b - TRIG_IN4 input is selected<br>01_1101b - TRIG_IN5 input is selected<br>01_1110b - TRIG_IN6 input is selected<br>01_1111b - TRIG_IN7 input is selected<br>10_0000b - TRIG_IN8 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 10_0001b - TRIG_IN9 input is selected<br>10_0010b - TRIG_IN10 input is selected<br>10_0011b - TRIG_IN11 input is selected<br>10_0100b - GPIO0 Pin Event Trig 0 input is selected<br>10_0101b - GPIO1 Pin Event Trig 0 input is selected<br>10_0110b - GPIO2 Pin Event Trig 0 input is selected<br>10_0111b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.18 QDC0 Trigger Input Connections (QDC0\_ICAP2)

#### Offset

| Register   | Offset |
|------------|--------|
| QDC0_ICAP2 | 378h   |

#### Function

This register selects the QDC0 trigger inputs.

#### Diagram



#### Fields

| Field | Function               |
|-------|------------------------|
| 31-6  | Reserved               |
| —     |                        |
| 5-0   | QDC0 input connections |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INP   | 00_0000b - Reserved<br>00_0001b - ARM_TXEV input is selected<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT2 input is selected<br>00_1010b - CTimer0_MAT3 input is selected<br>00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer1_MAT3 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - CTimer2_MAT3 input is selected<br>00_1111b - QDC0_POS_MATCH0 input is selected<br>01_0000b - PWM0_SM0_OUT_TRIG0 input is selected<br>01_0001b - PWM0_SM0_OUT_TRIG1 input is selected<br>01_0010b - PWM0_SM1_OUT_TRIG0 input is selected<br>01_0011b - PWM0_SM1_OUT_TRIG1 input is selected<br>01_0100b - PWM0_SM2_OUT_TRIG0 input is selected<br>01_0101b - PWM0_SM2_OUT_TRIG1 input is selected<br>01_0110b - Reserved<br>01_0111b - Reserved<br>01_1000b - TRIG_IN0 input is selected<br>01_1001b - TRIG_IN1 input is selected<br>01_1010b - TRIG_IN2 input is selected<br>01_1011b - TRIG_IN3 input is selected<br>01_1100b - TRIG_IN4 input is selected<br>01_1101b - TRIG_IN5 input is selected<br>01_1110b - TRIG_IN6 input is selected<br>01_1111b - TRIG_IN7 input is selected<br>10_0000b - TRIG_IN8 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 10_0001b - TRIG_IN9 input is selected<br>10_0010b - TRIG_IN10 input is selected<br>10_0011b - TRIG_IN11 input is selected<br>10_0100b - GPIO0 Pin Event Trig 0 input is selected<br>10_0101b - GPIO1 Pin Event Trig 0 input is selected<br>10_0110b - GPIO2 Pin Event Trig 0 input is selected<br>10_0111b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.19 QDC0 Trigger Input Connections (QDC0\_ICAP3)

#### Offset

| Register   | Offset |
|------------|--------|
| QDC0_ICAP3 | 37Ch   |

#### Function

This register selects the QDC0 trigger inputs.

#### Diagram



#### Fields

| Field | Function               |
|-------|------------------------|
| 31-6  | Reserved               |
| —     |                        |
| 5-0   | QDC0 input connections |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INP   | 00_0000b - Reserved<br>00_0001b - ARM_TXEV input is selected<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT2 input is selected<br>00_1010b - CTimer0_MAT3 input is selected<br>00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer1_MAT3 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - CTimer2_MAT3 input is selected<br>00_1111b - QDC0_POS_MATCH0 input is selected<br>01_0000b - PWM0_SM0_OUT_TRIG0 input is selected<br>01_0001b - PWM0_SM0_OUT_TRIG1 input is selected<br>01_0010b - PWM0_SM1_OUT_TRIG0 input is selected<br>01_0011b - PWM0_SM1_OUT_TRIG1 input is selected<br>01_0100b - PWM0_SM2_OUT_TRIG0 input is selected<br>01_0101b - PWM0_SM2_OUT_TRIG1 input is selected<br>01_0110b - Reserved<br>01_0111b - Reserved<br>01_1000b - TRIG_IN0 input is selected<br>01_1001b - TRIG_IN1 input is selected<br>01_1010b - TRIG_IN2 input is selected<br>01_1011b - TRIG_IN3 input is selected<br>01_1100b - TRIG_IN4 input is selected<br>01_1101b - TRIG_IN5 input is selected<br>01_1110b - TRIG_IN6 input is selected<br>01_1111b - TRIG_IN7 input is selected<br>10_0000b - TRIG_IN8 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 10_0001b - TRIG_IN9 input is selected<br>10_0010b - TRIG_IN10 input is selected<br>10_0011b - TRIG_IN11 input is selected<br>10_0100b - GPIO0 Pin Event Trig 0 input is selected<br>10_0101b - GPIO1 Pin Event Trig 0 input is selected<br>10_0110b - GPIO2 Pin Event Trig 0 input is selected<br>10_0111b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.20 PWM0 input trigger connections (FlexPWM0\_SM0\_EXTA0)

#### Offset

| Register           | Offset |
|--------------------|--------|
| FlexPWM0_SM0_EXTA0 | 3A0h   |

#### Function

This register selects the PWM0 trigger inputs.

#### Diagram



#### Fields

| Field | Function                           |
|-------|------------------------------------|
| 31-6  | Reserved                           |
| —     |                                    |
| 5-0   | Trigger input connections for PWM0 |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TRIGIN | 00_0000b - Reserved<br>00_0001b - ARM_TXEV input is selected<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT2 input is selected<br>00_1010b - CTimer0_MAT3 input is selected<br>00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer1_MAT3 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - CTimer2_MAT3 input is selected<br>00_1111b - QDC0_CMP_FLAG0 input is selected<br>01_0000b - QDC0_CMP_FLAG1 input is selected<br>01_0001b - QDC0_CMP_FLAG2 input is selected<br>01_0010b - QDC0_CMP_FLAG3 input is selected<br>01_0011b - QDC0_POS_MATCH0 input is selected<br>01_0100b - TRIG_IN0 input is selected<br>01_0101b - TRIG_IN1 input is selected<br>01_0110b - TRIG_IN2 input is selected<br>01_0111b - TRIG_IN3 input is selected<br>01_1000b - TRIG_IN4 input is selected<br>01_1001b - TRIG_IN5 input is selected<br>01_1010b - TRIG_IN6 input is selected<br>01_1011b - TRIG_IN7 input is selected<br>01_1100b - TRIG_IN8 input is selected<br>01_1101b - TRIG_IN9 input is selected<br>01_1110b - TRIG_IN10 input is selected<br>01_1111b - TRIG_IN11 input is selected<br>10_0000b - GPIO0 Pin Event Trig 0 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                            |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 10_0001b - GPIO1 Pin Event Trig 0 input is selected<br>10_0010b - GPIO2 Pin Event Trig 0 input is selected<br>10_0011b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.21 PWM0 input trigger connections (FlexPWM0\_SM0\_EXTSYNC0)

#### Offset

| Register                  | Offset |
|---------------------------|--------|
| FlexPWM0_SM0_EXTSY<br>NC0 | 3A4h   |

#### Function

This register selects the PWM0 trigger inputs.

#### Diagram



#### Fields

| Field         | Function                                                                                                                                     |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—     | Reserved                                                                                                                                     |
| 5-0<br>TRIGIN | Trigger input connections for PWM0<br>00_0000b - Reserved<br>00_0001b - ARM_TXEV input is selected<br>00_0010b - AOI0_OUT0 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT2 input is selected<br>00_1010b - CTimer0_MAT3 input is selected<br>00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer1_MAT3 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - CTimer2_MAT3 input is selected<br>00_1111b - QDC0_CMP_FLAG0 input is selected<br>01_0000b - QDC0_CMP_FLAG1 input is selected<br>01_0001b - QDC0_CMP_FLAG2 input is selected<br>01_0010b - QDC0_CMP_FLAG3 input is selected<br>01_0011b - QDC0_POS_MATCH0 input is selected<br>01_0100b - TRIG_IN0 input is selected<br>01_0101b - TRIG_IN1 input is selected<br>01_0110b - TRIG_IN2 input is selected<br>01_0111b - TRIG_IN3 input is selected<br>01_1000b - TRIG_IN4 input is selected<br>01_1001b - TRIG_IN5 input is selected<br>01_1010b - TRIG_IN6 input is selected<br>01_1011b - TRIG_IN7 input is selected<br>01_1100b - TRIG_IN8 input is selected<br>01_1101b - TRIG_IN9 input is selected<br>01_1110b - TRIG_IN10 input is selected<br>01_1111b - TRIG_IN11 input is selected<br>10_0000b - GPIO0 Pin Event Trig 0 input is selected<br>10_0001b - GPIO1 Pin Event Trig 0 input is selected<br>10_0010b - GPIO2 Pin Event Trig 0 input is selected<br>10_0011b - GPIO3 Pin Event Trig 0 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                       |
|-------|--------------------------------|
|       | All other values are reserved. |

### 13.5.1.22 PWM0 input trigger connections (FlexPWM0\_SM1\_EXTA1)

#### Offset

| Register           | Offset |
|--------------------|--------|
| FlexPWM0_SM1_EXTA1 | 3A8h   |

#### Function

This register selects the PWM0 trigger inputs.

#### Diagram

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

#### Fields

| Field         | Function                                                                                                                                                                                                                                                                   |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—     | Reserved                                                                                                                                                                                                                                                                   |
| 5-0<br>TRIGIN | Trigger input connections for PWM0<br>00_0000b - Reserved<br>00_0001b - ARM_TXEV input is selected<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT2 input is selected<br>00_1010b - CTimer0_MAT3 input is selected<br>00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer1_MAT3 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - CTimer2_MAT3 input is selected<br>00_1111b - QDC0_CMP_FLAG0 input is selected<br>01_0000b - QDC0_CMP_FLAG1 input is selected<br>01_0001b - QDC0_CMP_FLAG2 input is selected<br>01_0010b - QDC0_CMP_FLAG3 input is selected<br>01_0011b - QDC0_POS_MATCH0 input is selected<br>01_0100b - TRIG_IN0 input is selected<br>01_0101b - TRIG_IN1 input is selected<br>01_0110b - TRIG_IN2 input is selected<br>01_0111b - TRIG_IN3 input is selected<br>01_1000b - TRIG_IN4 input is selected<br>01_1001b - TRIG_IN5 input is selected<br>01_1010b - TRIG_IN6 input is selected<br>01_1011b - TRIG_IN7 input is selected<br>01_1100b - TRIG_IN8 input is selected<br>01_1101b - TRIG_IN9 input is selected<br>01_1110b - TRIG_IN10 input is selected<br>01_1111b - TRIG_IN11 input is selected<br>10_0000b - GPIO0 Pin Event Trig 0 input is selected<br>10_0001b - GPIO1 Pin Event Trig 0 input is selected<br>10_0010b - GPIO2 Pin Event Trig 0 input is selected<br>10_0011b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.23 PWM0 input trigger connections (FlexPWM0\_SM1\_EXTSYNC1)

#### Offset

| Register                  | Offset |
|---------------------------|--------|
| FlexPWM0_SM1_EXTSY<br>NC1 | 3ACh   |

#### Function

This register selects the PWM0 trigger inputs.

#### Diagram

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

#### Fields

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 5-0<br>TRIGIN | Trigger input connections for PWM0<br><br>00_0000b - Reserved<br>00_0001b - ARM_TXEV input is selected<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT2 input is selected |

Table continues on the next page...

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 00_1010b - CTimer0_MAT3 input is selected<br>00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer1_MAT3 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - CTimer2_MAT3 input is selected<br>00_1111b - QDC0_CMP_FLAG0 input is selected<br>01_0000b - QDC0_CMP_FLAG1 input is selected<br>01_0001b - QDC0_CMP_FLAG2 input is selected<br>01_0010b - QDC0_CMP_FLAG3 input is selected<br>01_0011b - QDC0_POS_MATCH0 input is selected<br>01_0100b - TRIG_IN0 input is selected<br>01_0101b - TRIG_IN1 input is selected<br>01_0110b - TRIG_IN2 input is selected<br>01_0111b - TRIG_IN3 input is selected<br>01_1000b - TRIG_IN4 input is selected<br>01_1001b - TRIG_IN5 input is selected<br>01_1010b - TRIG_IN6 input is selected<br>01_1011b - TRIG_IN7 input is selected<br>01_1100b - TRIG_IN8 input is selected<br>01_1101b - TRIG_IN9 input is selected<br>01_1110b - TRIG_IN10 input is selected<br>01_1111b - TRIG_IN11 input is selected<br>10_0000b - GPIO0 Pin Event Trig 0 input is selected<br>10_0001b - GPIO1 Pin Event Trig 0 input is selected<br>10_0010b - GPIO2 Pin Event Trig 0 input is selected<br>10_0011b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

#### 13.5.1.24 PWM0 input trigger connections (FlexPWM0\_SM2\_EXTA2)

##### Offset

| Register           | Offset |
|--------------------|--------|
| FlexPWM0_SM2_EXTA2 | 3B0h   |

**Function**

This register selects the PWM0 trigger inputs.

**Diagram**

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

**Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5-0<br>TRIGIN | Trigger input connections for PWM0<br>00_0000b - Reserved<br>00_0001b - ARM_TXEV input is selected<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT2 input is selected<br>00_1010b - CTimer0_MAT3 input is selected<br>00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer1_MAT3 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - CTimer2_MAT3 input is selected<br>00_1111b - QDC0_CMP_FLAG0 input is selected<br>01_0000b - QDC0_CMP_FLAG1 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 01_0001b - QDC0_CMP_FLAG2 input is selected<br>01_0010b - QDC0_CMP_FLAG3 input is selected<br>01_0011b - QDC0_POS_MATCH0 input is selected<br>01_0100b - TRIG_IN0 input is selected<br>01_0101b - TRIG_IN1 input is selected<br>01_0110b - TRIG_IN2 input is selected<br>01_0111b - TRIG_IN3 input is selected<br>01_1000b - TRIG_IN4 input is selected<br>01_1001b - TRIG_IN5 input is selected<br>01_1010b - TRIG_IN6 input is selected<br>01_1011b - TRIG_IN7 input is selected<br>01_1100b - TRIG_IN8 input is selected<br>01_1101b - TRIG_IN9 input is selected<br>01_1110b - TRIG_IN10 input is selected<br>01_1111b - TRIG_IN11 input is selected<br>10_0000b - GPIO0 Pin Event Trig 0 input is selected<br>10_0001b - GPIO1 Pin Event Trig 0 input is selected<br>10_0010b - GPIO2 Pin Event Trig 0 input is selected<br>10_0011b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.25 PWM0 input trigger connections (FlexPWM0\_SM2\_EXTSYNC2)

#### Offset

| Register                  | Offset |
|---------------------------|--------|
| FlexPWM0_SM2_EXTSY<br>NC2 | 3B4h   |

#### Function

This register selects the PWM0 trigger inputs.

**Diagram****Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5-0<br>TRIGIN | <p>Trigger input connections for PWM0</p> <ul style="list-style-type: none"> <li>00_0000b - Reserved</li> <li>00_0001b - ARM_TXEV input is selected</li> <li>00_0010b - AOI0_OUT0 input is selected</li> <li>00_0011b - AOI0_OUT1 input is selected</li> <li>00_0100b - AOI0_OUT2 input is selected</li> <li>00_0101b - AOI0_OUT3 input is selected</li> <li>00_0110b - CMP0_OUT input is selected</li> <li>00_0111b - CMP1_OUT input is selected</li> <li>00_1000b - Reserved</li> <li>00_1001b - CTimer0_MAT2 input is selected</li> <li>00_1010b - CTimer0_MAT3 input is selected</li> <li>00_1011b - CTimer1_MAT2 input is selected</li> <li>00_1100b - CTimer1_MAT3 input is selected</li> <li>00_1101b - CTimer2_MAT2 input is selected</li> <li>00_1110b - CTimer2_MAT3 input is selected</li> <li>00_1111b - QDC0_CMP_FLAG0 input is selected</li> <li>01_0000b - QDC0_CMP_FLAG1 input is selected</li> <li>01_0001b - QDC0_CMP_FLAG2 input is selected</li> <li>01_0010b - QDC0_CMP_FLAG3 input is selected</li> <li>01_0011b - QDC0_POS_MATCH0 input is selected</li> </ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 01_0100b - TRIG_IN0 input is selected<br>01_0101b - TRIG_IN1 input is selected<br>01_0110b - TRIG_IN2 input is selected<br>01_0111b - TRIG_IN3 input is selected<br>01_1000b - TRIG_IN4 input is selected<br>01_1001b - TRIG_IN5 input is selected<br>01_1010b - TRIG_IN6 input is selected<br>01_1011b - TRIG_IN7 input is selected<br>01_1100b - TRIG_IN8 input is selected<br>01_1101b - TRIG_IN9 input is selected<br>01_1110b - TRIG_IN10 input is selected<br>01_1111b - TRIG_IN11 input is selected<br>10_0000b - GPIO0 Pin Event Trig 0 input is selected<br>10_0001b - GPIO1 Pin Event Trig 0 input is selected<br>10_0010b - GPIO2 Pin Event Trig 0 input is selected<br>10_0011b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.26 PWM0 input trigger connections (FlexPWM0\_FAULT0)

#### Offset

| Register        | Offset |
|-----------------|--------|
| FlexPWM0_FAULT0 | 3C0h   |

#### Function

This register selects the PWM0 trigger inputs.

**Diagram****Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5-0<br>TRIGIN | <p>Trigger input connections for PWM0</p> <ul style="list-style-type: none"> <li>00_0000b - Reserved</li> <li>00_0001b - ARM_TXEV input is selected</li> <li>00_0010b - AOI0_OUT0 input is selected</li> <li>00_0011b - AOI0_OUT1 input is selected</li> <li>00_0100b - AOI0_OUT2 input is selected</li> <li>00_0101b - AOI0_OUT3 input is selected</li> <li>00_0110b - CMP0_OUT input is selected</li> <li>00_0111b - CMP1_OUT input is selected</li> <li>00_1000b - Reserved</li> <li>00_1001b - CTimer0_MAT2 input is selected</li> <li>00_1010b - CTimer0_MAT3 input is selected</li> <li>00_1011b - CTimer1_MAT2 input is selected</li> <li>00_1100b - CTimer1_MAT3 input is selected</li> <li>00_1101b - CTimer2_MAT2 input is selected</li> <li>00_1110b - CTimer2_MAT3 input is selected</li> <li>00_1111b - QDC0_CMP_FLAG0 input is selected</li> <li>01_0000b - QDC0_CMP_FLAG1 input is selected</li> <li>01_0001b - QDC0_CMP_FLAG2 input is selected</li> <li>01_0010b - QDC0_CMP_FLAG3 input is selected</li> <li>01_0011b - QDC0_POS_MATCH0 input is selected</li> </ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 01_0100b - TRIG_IN0 input is selected<br>01_0101b - TRIG_IN1 input is selected<br>01_0110b - TRIG_IN2 input is selected<br>01_0111b - TRIG_IN3 input is selected<br>01_1000b - TRIG_IN4 input is selected<br>01_1001b - TRIG_IN5 input is selected<br>01_1010b - TRIG_IN6 input is selected<br>01_1011b - TRIG_IN7 input is selected<br>01_1100b - TRIG_IN8 input is selected<br>01_1101b - TRIG_IN9 input is selected<br>01_1110b - TRIG_IN10 input is selected<br>01_1111b - TRIG_IN11 input is selected<br>10_0000b - GPIO0 Pin Event Trig 0 input is selected<br>10_0001b - GPIO1 Pin Event Trig 0 input is selected<br>10_0010b - GPIO2 Pin Event Trig 0 input is selected<br>10_0011b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.27 PWM0 input trigger connections (FlexPWM0\_FAULT1)

#### Offset

| Register        | Offset |
|-----------------|--------|
| FlexPWM0_FAULT1 | 3C4h   |

#### Function

This register selects the PWM0 trigger inputs.

**Diagram****Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5-0<br>TRIGIN | <p>Trigger input connections for PWM0</p> <ul style="list-style-type: none"> <li>00_0000b - Reserved</li> <li>00_0001b - ARM_TXEV input is selected</li> <li>00_0010b - AOI0_OUT0 input is selected</li> <li>00_0011b - AOI0_OUT1 input is selected</li> <li>00_0100b - AOI0_OUT2 input is selected</li> <li>00_0101b - AOI0_OUT3 input is selected</li> <li>00_0110b - CMP0_OUT input is selected</li> <li>00_0111b - CMP1_OUT input is selected</li> <li>00_1000b - Reserved</li> <li>00_1001b - CTimer0_MAT2 input is selected</li> <li>00_1010b - CTimer0_MAT3 input is selected</li> <li>00_1011b - CTimer1_MAT2 input is selected</li> <li>00_1100b - CTimer1_MAT3 input is selected</li> <li>00_1101b - CTimer2_MAT2 input is selected</li> <li>00_1110b - CTimer2_MAT3 input is selected</li> <li>00_1111b - QDC0_CMP_FLAG0 input is selected</li> <li>01_0000b - QDC0_CMP_FLAG1 input is selected</li> <li>01_0001b - QDC0_CMP_FLAG2 input is selected</li> <li>01_0010b - QDC0_CMP_FLAG3 input is selected</li> <li>01_0011b - QDC0_POS_MATCH0 input is selected</li> </ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 01_0100b - TRIG_IN0 input is selected<br>01_0101b - TRIG_IN1 input is selected<br>01_0110b - TRIG_IN2 input is selected<br>01_0111b - TRIG_IN3 input is selected<br>01_1000b - TRIG_IN4 input is selected<br>01_1001b - TRIG_IN5 input is selected<br>01_1010b - TRIG_IN6 input is selected<br>01_1011b - TRIG_IN7 input is selected<br>01_1100b - TRIG_IN8 input is selected<br>01_1101b - TRIG_IN9 input is selected<br>01_1110b - TRIG_IN10 input is selected<br>01_1111b - TRIG_IN11 input is selected<br>10_0000b - GPIO0 Pin Event Trig 0 input is selected<br>10_0001b - GPIO1 Pin Event Trig 0 input is selected<br>10_0010b - GPIO2 Pin Event Trig 0 input is selected<br>10_0011b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.28 PWM0 input trigger connections (FlexPWM0\_FAULT2)

#### Offset

| Register        | Offset |
|-----------------|--------|
| FlexPWM0_FAULT2 | 3C8h   |

#### Function

This register selects the PWM0 trigger inputs.

**Diagram****Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5-0<br>TRIGIN | <p>Trigger input connections for PWM0</p> <ul style="list-style-type: none"> <li>00_0000b - Reserved</li> <li>00_0001b - ARM_TXEV input is selected</li> <li>00_0010b - AOI0_OUT0 input is selected</li> <li>00_0011b - AOI0_OUT1 input is selected</li> <li>00_0100b - AOI0_OUT2 input is selected</li> <li>00_0101b - AOI0_OUT3 input is selected</li> <li>00_0110b - CMP0_OUT input is selected</li> <li>00_0111b - CMP1_OUT input is selected</li> <li>00_1000b - Reserved</li> <li>00_1001b - CTimer0_MAT2 input is selected</li> <li>00_1010b - CTimer0_MAT3 input is selected</li> <li>00_1011b - CTimer1_MAT2 input is selected</li> <li>00_1100b - CTimer1_MAT3 input is selected</li> <li>00_1101b - CTimer2_MAT2 input is selected</li> <li>00_1110b - CTimer2_MAT3 input is selected</li> <li>00_1111b - QDC0_CMP_FLAG0 input is selected</li> <li>01_0000b - QDC0_CMP_FLAG1 input is selected</li> <li>01_0001b - QDC0_CMP_FLAG2 input is selected</li> <li>01_0010b - QDC0_CMP_FLAG3 input is selected</li> <li>01_0011b - QDC0_POS_MATCH0 input is selected</li> </ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 01_0100b - TRIG_IN0 input is selected<br>01_0101b - TRIG_IN1 input is selected<br>01_0110b - TRIG_IN2 input is selected<br>01_0111b - TRIG_IN3 input is selected<br>01_1000b - TRIG_IN4 input is selected<br>01_1001b - TRIG_IN5 input is selected<br>01_1010b - TRIG_IN6 input is selected<br>01_1011b - TRIG_IN7 input is selected<br>01_1100b - TRIG_IN8 input is selected<br>01_1101b - TRIG_IN9 input is selected<br>01_1110b - TRIG_IN10 input is selected<br>01_1111b - TRIG_IN11 input is selected<br>10_0000b - GPIO0 Pin Event Trig 0 input is selected<br>10_0001b - GPIO1 Pin Event Trig 0 input is selected<br>10_0010b - GPIO2 Pin Event Trig 0 input is selected<br>10_0011b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.29 PWM0 input trigger connections (FlexPWM0\_FAULT3)

#### Offset

| Register        | Offset |
|-----------------|--------|
| FlexPWM0_FAULT3 | 3CCh   |

#### Function

This register selects the PWM0 trigger inputs.

**Diagram****Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5-0<br>TRIGIN | <p>Trigger input connections for PWM0</p> <ul style="list-style-type: none"> <li>00_0000b - Reserved</li> <li>00_0001b - ARM_TXEV input is selected</li> <li>00_0010b - AOI0_OUT0 input is selected</li> <li>00_0011b - AOI0_OUT1 input is selected</li> <li>00_0100b - AOI0_OUT2 input is selected</li> <li>00_0101b - AOI0_OUT3 input is selected</li> <li>00_0110b - CMP0_OUT input is selected</li> <li>00_0111b - CMP1_OUT input is selected</li> <li>00_1000b - Reserved</li> <li>00_1001b - CTimer0_MAT2 input is selected</li> <li>00_1010b - CTimer0_MAT3 input is selected</li> <li>00_1011b - CTimer1_MAT2 input is selected</li> <li>00_1100b - CTimer1_MAT3 input is selected</li> <li>00_1101b - CTimer2_MAT2 input is selected</li> <li>00_1110b - CTimer2_MAT3 input is selected</li> <li>00_1111b - QDC0_CMP_FLAG0 input is selected</li> <li>01_0000b - QDC0_CMP_FLAG1 input is selected</li> <li>01_0001b - QDC0_CMP_FLAG2 input is selected</li> <li>01_0010b - QDC0_CMP_FLAG3 input is selected</li> <li>01_0011b - QDC0_POS_MATCH0 input is selected</li> </ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 01_0100b - TRIG_IN0 input is selected<br>01_0101b - TRIG_IN1 input is selected<br>01_0110b - TRIG_IN2 input is selected<br>01_0111b - TRIG_IN3 input is selected<br>01_1000b - TRIG_IN4 input is selected<br>01_1001b - TRIG_IN5 input is selected<br>01_1010b - TRIG_IN6 input is selected<br>01_1011b - TRIG_IN7 input is selected<br>01_1100b - TRIG_IN8 input is selected<br>01_1101b - TRIG_IN9 input is selected<br>01_1110b - TRIG_IN10 input is selected<br>01_1111b - TRIG_IN11 input is selected<br>10_0000b - GPIO0 Pin Event Trig 0 input is selected<br>10_0001b - GPIO1 Pin Event Trig 0 input is selected<br>10_0010b - GPIO2 Pin Event Trig 0 input is selected<br>10_0011b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.30 PWM0 input trigger connections (FlexPWM0\_FORCE)

#### Offset

| Register       | Offset |
|----------------|--------|
| FlexPWM0_FORCE | 3D0h   |

#### Function

This register selects the PWM0 trigger inputs.

**Diagram****Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5-0<br>TRIGIN | <p>Trigger input connections for PWM0</p> <ul style="list-style-type: none"> <li>00_0000b - Reserved</li> <li>00_0001b - ARM_TXEV input is selected</li> <li>00_0010b - AOI0_OUT0 input is selected</li> <li>00_0011b - AOI0_OUT1 input is selected</li> <li>00_0100b - AOI0_OUT2 input is selected</li> <li>00_0101b - AOI0_OUT3 input is selected</li> <li>00_0110b - CMP0_OUT input is selected</li> <li>00_0111b - CMP1_OUT input is selected</li> <li>00_1000b - Reserved</li> <li>00_1001b - CTimer0_MAT2 input is selected</li> <li>00_1010b - CTimer0_MAT3 input is selected</li> <li>00_1011b - CTimer1_MAT2 input is selected</li> <li>00_1100b - CTimer1_MAT3 input is selected</li> <li>00_1101b - CTimer2_MAT2 input is selected</li> <li>00_1110b - CTimer2_MAT3 input is selected</li> <li>00_1111b - QDC0_CMP_FLAG0 input is selected</li> <li>01_0000b - QDC0_CMP_FLAG1 input is selected</li> <li>01_0001b - QDC0_CMP_FLAG2 input is selected</li> <li>01_0010b - QDC0_CMP_FLAG3 input is selected</li> <li>01_0011b - QDC0_POS_MATCH0 input is selected</li> </ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 01_0100b - TRIG_IN0 input is selected<br>01_0101b - TRIG_IN1 input is selected<br>01_0110b - TRIG_IN2 input is selected<br>01_0111b - TRIG_IN3 input is selected<br>01_1000b - TRIG_IN4 input is selected<br>01_1001b - TRIG_IN5 input is selected<br>01_1010b - TRIG_IN6 input is selected<br>01_1011b - TRIG_IN7 input is selected<br>01_1100b - TRIG_IN8 input is selected<br>01_1101b - TRIG_IN9 input is selected<br>01_1110b - TRIG_IN10 input is selected<br>01_1111b - TRIG_IN11 input is selected<br>10_0000b - GPIO0 Pin Event Trig 0 input is selected<br>10_0001b - GPIO1 Pin Event Trig 0 input is selected<br>10_0010b - GPIO2 Pin Event Trig 0 input is selected<br>10_0011b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.31 PWM0 external clock trigger (PWM0\_EXT\_CLK)

#### Offset

| Register     | Offset |
|--------------|--------|
| PWM0_EXT_CLK | 420h   |

#### Function

PWM0 external clock trigger connections

**Diagram****Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                     |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3          | Reserved                                                                                                                                                                                                                                                                                                                     |
| —             |                                                                                                                                                                                                                                                                                                                              |
| 2-0<br>TRIGIN | Trigger input connections for PWM<br>000b - Reserved<br>001b - clk_16k[1] input is selected<br>010b - clk_in input is selected<br>011b - AOI0_OUT0 input is selected<br>100b - AOI0_OUT1 input is selected<br>101b - EXTTRIG_IN0 input is selected<br>110b - EXTTRIG_IN7 input is selected<br>All other values are reserved. |

**13.5.1.32 AOI0 trigger input connections 0-15 (AOI0\_MUX0 - AOI0\_MUX15)****Offset**

For a = 0 to 15:

| Register  | Offset          |
|-----------|-----------------|
| AOI0_MUXa | 440h + (a × 4h) |

**Function**

This register is used to select the AOI0 trigger inputs.

**Diagram****Fields**

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5-0<br>INP | AOI0 trigger input connections<br>00_0000b - Reserved<br>00_0001b - ADC0_tcomp[0] input is selected<br>00_0010b - ADC0_tcomp[1] input is selected<br>00_0011b - ADC0_tcomp[2] input is selected<br>00_0100b - ADC0_tcomp[3] input is selected<br>00_0101b - CMP0_OUT input is selected<br>00_0110b - CMP1_OUT input is selected<br>00_0111b - Reserved<br>00_1000b - CTimer0_MAT0 input is selected<br>00_1001b - CTimer0_MAT1 input is selected<br>00_1010b - CTimer0_MAT2 input is selected<br>00_1011b - CTimer0_MAT3 input is selected<br>00_1100b - CTimer1_MAT0 input is selected<br>00_1101b - CTimer1_MAT1 input is selected<br>00_1110b - CTimer1_MAT2 input is selected<br>00_1111b - CTimer1_MAT3 input is selected<br>01_0000b - CTimer2_MAT0 input is selected<br>01_0001b - CTimer2_MAT1 input is selected<br>01_0010b - CTimer2_MAT2 input is selected<br>01_0011b - CTimer2_MAT3 input is selected |

Table continues on the next page...

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 01_0100b - LPTMR0 input is selected<br>01_0101b - Reserved<br>01_0110b - QDC0_CMP_FLAG0 input input is selected<br>01_0111b - QDC0_CMP_FLAG1 input is selected<br>01_1000b - QDC0_CMP_FLAG2 input is selected<br>01_1001b - QDC0_CMP_FLAG3 input is selected<br>01_1010b - QDC0_POS_MATCH input is selected<br>01_1011b - PWM0_SM0_OUT_TRIG0 0 input is selected<br>01_1100b - PWM0_SM0_OUT_TRIG1 input is selected<br>01_1101b - PWM0_SM1_OUT_TRIG0 input is selected<br>01_1110b - PWM0_SM1_OUT_TRIG1 input is selected<br>01_1111b - PWM0_SM2_OUT_TRIG0 input is selected<br>10_0000b - PWM0_SM2_OUT_TRIG1 input is selected<br>10_0001b - Reserved<br>10_0010b - Reserved<br>10_0011b - TRIG_IN0 input is selected<br>10_0100b - TRIG_IN1 input is selected<br>10_0101b - TRIG_IN2 input is selected<br>10_0110b - TRIG_IN3 input is selected<br>10_0111b - TRIG_IN4 input is selected<br>10_1000b - TRIG_IN5 input is selected<br>10_1001b - TRIG_IN6 input is selected<br>10_1010b - TRIG_IN7 input is selected<br>10_1011b - TRIG_IN8 input is selected<br>10_1100b - TRIG_IN9 input is selected<br>10_1101b - TRIG_IN10 input is selected<br>10_1110b - TRIG_IN11 input is selected<br>10_1111b - GPIO0 Pin Event Trig 0 input is selected<br>11_0000b - GPIO1 Pin Event Trig 0 input is selected<br>11_0001b - GPIO2 Pin Event Trig 0 input is selected<br>11_0010b - GPIO3 Pin Event Trig 0 input is selected<br>All other values are reserved. |

### 13.5.1.33 USB-FS trigger input connections (USBFS\_TRIG)

#### Offset

| Register   | Offset |
|------------|--------|
| USBFS_TRIG | 480h   |

#### Function

This register is used to select the USB-FS trigger inputs.

#### Diagram



#### Fields

| Field | Function                                                                                                                                                                                                            |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3  | Reserved                                                                                                                                                                                                            |
| —     |                                                                                                                                                                                                                     |
| 2-0   | USB-FS trigger input connections.                                                                                                                                                                                   |
| INP   | 000b - Reserved<br>001b - LPUART0 lpuart_trg_txdata input is selected<br>010b - LPUART1 lpuart_trg_txdata input is selected<br>011b - LPUART2 lpuart_trg_txdata input is selected<br>All other values are reserved. |

### 13.5.1.34 EXT trigger connections 0-4 (EXT\_TRIG0 - EXT\_TRIG4)

#### Offset

| Register  | Offset |
|-----------|--------|
| EXT_TRIG0 | 4C0h   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Register  | Offset |
|-----------|--------|
| EXT_TRIG1 | 4C4h   |
| EXT_TRIG2 | 4C8h   |
| EXT_TRIG3 | 4CCh   |
| EXT_TRIG4 | 4D0h   |

### Function

This register is used to select the EXT trigger inputs.

### Diagram



### Fields

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-5<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4-0<br>INP | EXT trigger input connections<br><br>0_0000b - Reserved<br>0_0001b - ARM_TXEV input is selected<br>0_0010b - AOI0_OUT0 input is selected<br>0_0011b - AOI0_OUT1 input is selected<br>0_0100b - AOI0_OUT2 input is selected<br>0_0101b - AOI0_OUT3 input is selected<br>0_0110b - CMP0_OUT input is selected<br>0_0111b - CMP1_OUT input is selected<br>0_1000b - Reserved<br>0_1001b - LPUART0 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                     |
|-------|--------------------------------------------------------------------------------------------------------------|
|       | 0_1010b - LPUART1 input is selected<br>0_1011b - LPUART2 input is selected<br>All other values are reserved. |

### 13.5.1.35 EXT trigger connections 6-7 (EXT\_TRIG6 - EXT\_TRIG7)

#### Offset

| Register  | Offset |
|-----------|--------|
| EXT_TRIG6 | 4D8h   |
| EXT_TRIG7 | 4DCh   |

#### Function

This register is used to select the EXT trigger inputs.

#### Diagram



#### Fields

| Field      | Function                                                                                                                             |
|------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 31-5<br>—  | Reserved                                                                                                                             |
| 4-0<br>INP | EXT trigger input connections<br>0_0000b - Reserved<br>0_0001b - ARM_TXEV input is selected<br>0_0010b - AOI0_OUT0 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                             |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 0_0011b - AOI0_OUT1 input is selected<br>0_0100b - AOI0_OUT2 input is selected<br>0_0101b - AOI0_OUT3 input is selected<br>0_0110b - CMP0_OUT input is selected<br>0_0111b - CMP1_OUT input is selected<br>0_1000b - Reserved<br>0_1001b - LPUART0 input is selected<br>0_1010b - LPUART1 input is selected<br>0_1011b - LPUART2 input is selected<br>All other values are reserved. |

### 13.5.1.36 CMP1 input connections (CMP1\_TRIG)

#### Offset

| Register  | Offset |
|-----------|--------|
| CMP1_TRIG | 4E0h   |

#### Function

This register selects the CMP1 trigger inputs.

#### Diagram



#### Fields

| Field | Function |
|-------|----------|
| 31-6  | Reserved |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 5-0<br>TRIGIN | CMP0 input trigger<br>00_0000b - Reserved<br>00_0001b - ARM_TXEV input is selected<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - Reserved<br>00_1000b - CTimer0_MAT0 input is selected<br>00_1001b - CTimer0_MAT2 input is selected<br>00_1010b - CTimer1_MAT0 input is selected<br>00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer2_MAT0 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - LPTMR0 input is selected<br>00_1111b - Reserved<br>01_0000b - QDC0_CMP/POS_MATCH0<br>01_0001b - PWM0_SM0_OUT_TRIG0 input is selected<br>01_0010b - PWM0_SM0_OUT_TRIG1 input is selected<br>01_0011b - PWM0_SM1_OUT_TRIG0 input is selected<br>01_0100b - PWM0_SM1_OUT_TRIG1 input is selected<br>01_0101b - PWM0_SM2_OUT_TRIG0 input is selected<br>01_0110b - PWM0_SM2_OUT_TRIG1 input is selected<br>01_0111b - Reserved<br>01_1000b - Reserved<br>01_1001b - GPIO0 Pin Event Trig 0 input is selected<br>01_1010b - GPIO1 Pin Event Trig 0 input is selected<br>01_1011b - GPIO2 Pin Event Trig 0 input is selected<br>01_1100b - GPIO3 Pin Event Trig 0 input is selected<br>01_1101b - Reserved<br>01_1110b - WUU input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                       |
|-------|--------------------------------|
|       | All other values are reserved. |

### 13.5.1.37 LPI2C0 trigger input connections (LPI2C0\_TRIG)

#### Offset

| Register    | Offset |
|-------------|--------|
| LPI2C0_TRIG | 5A0h   |

#### Function

This register is used to select the LPI2C0 trigger inputs.

#### Diagram



#### Fields

| Field      | Function                                                                                                                                                                                                                                               |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—  | Reserved                                                                                                                                                                                                                                               |
| 5-0<br>INP | LPI2C0 trigger input connections<br>00_0000b - Reserved<br>00_0001b - ARM_TXEV<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT0 input is selected<br>00_1010b - CTimer0_MAT1 input is selected<br>00_1011b - CTimer1_MAT0 input is selected<br>00_1100b - CTimer1_MAT1 input is selected<br>00_1101b - CTimer2_MAT0 input is selected<br>00_1110b - CTimer2_MAT1 input is selected<br>00_1111b - LPTMR0 input is selected<br>01_0000b - Reserved<br>01_0001b - TRIG_IN0 input is selected<br>01_0010b - TRIG_IN1 input is selected<br>01_0011b - TRIG_IN2 input is selected<br>01_0100b - TRIG_IN3 input is selected<br>01_0101b - TRIG_IN4 input is selected<br>01_0110b - TRIG_IN5 input is selected<br>01_0111b - TRIG_IN6 input is selected<br>01_1000b - TRIG_IN7 input is selected<br>01_1001b - GPIO0 Pin Event Trig 0 input is selected<br>01_1010b - GPIO1 Pin Event Trig 0 input is selected<br>01_1011b - GPIO2 Pin Event Trig 0 input is selected<br>01_1100b - GPIO3 Pin Event Trig 0 input is selected<br>10_1010b - WUU input is selected<br>All other values are reserved. |

### 13.5.1.38 LPSP10 trigger input connections (LPSP10\_TRIG)

#### Offset

| Register    | Offset |
|-------------|--------|
| LPSP10_TRIG | 5E0h   |

#### Function

This register is used to select the LPSP10 trigger inputs.

**Diagram**

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

**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5-0<br>INP | LPSPI0 trigger input connections<br><br>00_0000b - Reserved<br>00_0001b - ARM_TXEV<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT1 input is selected<br>00_1010b - CTimer0_MAT2 input is selected<br>00_1011b - CTimer1_MAT1 input is selected<br>00_1100b - CTimer1_MAT2 input is selected<br>00_1101b - CTimer2_MAT1 input is selected<br>00_1110b - CTimer2_MAT2 input is selected<br>00_1111b - LPTMR0 input is selected<br>01_0000b - Reserved<br>01_0001b - TRIG_IN0 input is selected<br>01_0010b - TRIG_IN1 input is selected<br>01_0011b - TRIG_IN2 input is selected |

Table continues on the next page...

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 01_0100b - TRIG_IN3 input is selected<br>01_0101b - TRIG_IN4 input is selected<br>01_0110b - TRIG_IN5 input is selected<br>01_0111b - TRIG_IN6 input is selected<br>01_1000b - TRIG_IN7 input is selected<br>01_1001b - GPIO0 Pin Event Trig 0 input is selected<br>01_1010b - GPIO1 Pin Event Trig 0 input is selected<br>01_1011b - GPIO2 Pin Event Trig 0 input is selected<br>01_1100b - GPIO3 Pin Event Trig 0 input is selected<br>10_1010b - WUU input is selected<br>All other values are reserved. |

### 13.5.1.39 LPSPI1 trigger input connections (LPSPI1\_TRIG)

#### Offset

| Register    | Offset |
|-------------|--------|
| LPSPI1_TRIG | 600h   |

#### Function

This register is used to select the LPSPI1 trigger inputs.

#### Diagram



**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 5-0<br>INP | LPSPI1 trigger input connections<br>00_0000b - Reserved<br>00_0001b - ARM_TXEV<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT1 input is selected<br>00_1010b - CTimer0_MAT2 input is selected<br>00_1011b - CTimer1_MAT1 input is selected<br>00_1100b - CTimer1_MAT2 input is selected<br>00_1101b - CTimer2_MAT1 input is selected<br>00_1110b - CTimer2_MAT2 input is selected<br>00_1111b - LPTMR0 input is selected<br>01_0000b - Reserved<br>01_0001b - TRIG_IN0 input is selected<br>01_0010b - TRIG_IN1 input is selected<br>01_0011b - TRIG_IN2 input is selected<br>01_0100b - TRIG_IN3 input is selected<br>01_0101b - TRIG_IN4 input is selected<br>01_0110b - TRIG_IN5 input is selected<br>01_0111b - TRIG_IN6 input is selected<br>01_1000b - TRIG_IN7 input is selected<br>01_1001b - GPIO0 Pin Event Trig 0 input is selected<br>01_1010b - GPIO1 Pin Event Trig 0 input is selected<br>01_1011b - GPIO2 Pin Event Trig 0 input is selected<br>01_1100b - GPIO3 Pin Event Trig 0 input is selected<br>10_1010b - WUU input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                       |
|-------|--------------------------------|
|       | All other values are reserved. |

### 13.5.1.40 LPUART0 trigger input connections (LPUART0)

#### Offset

| Register | Offset |
|----------|--------|
| LPUART0  | 620h   |

#### Function

This register is used to select the LPUART0 trigger inputs.

#### Diagram



#### Fields

| Field      | Function                                                                                                                                                                                                                                                |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—  | Reserved                                                                                                                                                                                                                                                |
| 5-0<br>INP | LPUART0 trigger input connections<br>00_0000b - Reserved<br>00_0001b - ARM_TXEV<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT2 input is selected<br>00_1010b - CTimer0_MAT3 input is selected<br>00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer1_MAT3 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - CTimer2_MAT3 input is selected<br>00_1111b - LPTMR0 input is selected<br>01_0000b - Reserved<br>01_0001b - TRIG_IN0 input is selected<br>01_0010b - TRIG_IN1 input is selected<br>01_0011b - TRIG_IN2 input is selected<br>01_0100b - TRIG_IN3 input is selected<br>01_0101b - TRIG_IN4 input is selected<br>01_0110b - TRIG_IN5 input is selected<br>01_0111b - TRIG_IN6 input is selected<br>01_1000b - TRIG_IN7 input is selected<br>01_1001b - TRIG_IN8 input is selected<br>01_1010b - TRIG_IN9 input is selected<br>01_1011b - TRIG_IN10 input is selected<br>01_1100b - TRIG_IN11 input is selected<br>01_1101b - GPIO0 Pin Event Trig 0 input is selected<br>01_1110b - GPIO0 Pin Event Trig 0 input is selected<br>01_1111b - GPIO0 Pin Event Trig 0 input is selected<br>10_0000b - GPIO0 Pin Event Trig 0 input is selected<br>10_0001b - Reserved<br>10_0010b - WUU input is selected<br>10_0011b - USB0_ipp_ind_uart_rxd_usbmux input is selected<br>All other values are reserved. |

### 13.5.1.41 LPUART1 trigger input connections (LPUART1)

#### Offset

| Register | Offset |
|----------|--------|
| LPUART1  | 640h   |

#### Function

This register is used to select the LPUART1 trigger inputs.

#### Diagram



#### Fields

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5-0<br>INP | LPUART1 trigger input connections<br>00_0000b - Reserved<br>00_0001b - ARM_TXEV<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT2 input is selected<br>00_1010b - CTimer0_MAT3 input is selected |

Table continues on the next page...

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer1_MAT3 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - CTimer2_MAT3 input is selected<br>00_1111b - LPTMR0 input is selected<br>01_0000b - Reserved<br>01_0001b - TRIG_IN0 input is selected<br>01_0010b - TRIG_IN1 input is selected<br>01_0011b - TRIG_IN2 input is selected<br>01_0100b - TRIG_IN3 input is selected<br>01_0101b - TRIG_IN4 input is selected<br>01_0110b - TRIG_IN5 input is selected<br>01_0111b - TRIG_IN6 input is selected<br>01_1000b - TRIG_IN7 input is selected<br>01_1001b - TRIG_IN8 input is selected<br>01_1010b - TRIG_IN9 input is selected<br>01_1011b - TRIG_IN10 input is selected<br>01_1100b - TRIG_IN11 input is selected<br>01_1101b - GPIO0 Pin Event Trig 0 input is selected<br>01_1110b - GPIO0 Pin Event Trig 0 input is selected<br>01_1111b - GPIO0 Pin Event Trig 0 input is selected<br>10_0000b - GPIO0 Pin Event Trig 0 input is selected<br>10_0001b - Reserved<br>10_0010b - WUU input is selected<br>10_0011b - USB0 ipp_ind_uart_rxd_usbmux input is selected<br>All other values are reserved. |

### 13.5.1.42 LPUART2 trigger input connections (LPUART2)

#### Offset

| Register | Offset |
|----------|--------|
| LPUART2  | 660h   |

#### Function

This register is used to select the LPUART2 trigger inputs.

**Diagram****Fields**

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 5-0<br>INP | LPUART2 trigger input connections<br><br>00_0000b - Reserved<br>00_0001b - ARM_TXEV<br>00_0010b - AOI0_OUT0 input is selected<br>00_0011b - AOI0_OUT1 input is selected<br>00_0100b - AOI0_OUT2 input is selected<br>00_0101b - AOI0_OUT3 input is selected<br>00_0110b - CMP0_OUT input is selected<br>00_0111b - CMP1_OUT input is selected<br>00_1000b - Reserved<br>00_1001b - CTimer0_MAT2 input is selected<br>00_1010b - CTimer0_MAT3 input is selected<br>00_1011b - CTimer1_MAT2 input is selected<br>00_1100b - CTimer1_MAT3 input is selected<br>00_1101b - CTimer2_MAT2 input is selected<br>00_1110b - CTimer2_MAT3 input is selected<br>00_1111b - LPTMR0 input is selected<br>01_0000b - Reserved<br>01_0001b - TRIG_IN0 input is selected<br>01_0010b - TRIG_IN1 input is selected<br>01_0011b - TRIG_IN2 input is selected |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 01_0100b - TRIG_IN3 input is selected<br>01_0101b - TRIG_IN4 input is selected<br>01_0110b - TRIG_IN5 input is selected<br>01_0111b - TRIG_IN6 input is selected<br>01_1000b - TRIG_IN7 input is selected<br>01_1001b - TRIG_IN8 input is selected<br>01_1010b - TRIG_IN9 input is selected<br>01_1011b - TRIG_IN10 input is selected<br>01_1100b - TRIG_IN11 input is selected<br>01_1101b - GPIO0 Pin Event Trig 0 input is selected<br>01_1110b - GPIO0 Pin Event Trig 0 input is selected<br>01_1111b - GPIO0 Pin Event Trig 0 input is selected<br>10_0000b - GPIO0 Pin Event Trig 0 input is selected<br>10_0001b - Reserved<br>10_0010b - WUU input is selected<br>10_0011b - USB0 ipp_ind_uart_rxd_usbmux input is selected<br>All other values are reserved. |

# Chapter 14

## System Controller (SYSCON)

### 14.1 Chip-specific SYSCON information

Table 72. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | SYSCON         | <a href="#">SYSCON</a>              |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 14.1.1 Module instances

This device has one instance of SYSCON module.

#### 14.1.2 Configuration

Configure the SYSCON block as follows:

- No clock configuration is needed. The clock to the SYSCON block is always enabled.
- The SYSCON block controls use of the CLKOUT pin, which must also be configured through Port control module.

## 14.2 Overview

The SYSCON module provides controls and configurations on the system and peripherals for the multiple functions.

### 14.2.1 Features

The SYSCON module supports the following features and configurations:

- System and bus configuration
  - AHB matrix priority
  - CPUs control and status
  - CPU debug access
  - CPU LPCAC control
  - NMI source select
  - Calibrate system tick timer
  - Boot control
- System/Peripherals - clock select and control
  - Allows enabling and selection of clocks to individual peripherals and memories
  - Allows configuration of clock dividers
- Memory configuration
  - ROM access

- RAM ECC
- FLASH cache, bus error
- Gray-2-Binary converter
  - Allows decoding gray value coming from OS Event Timer
- Peripherals configuration
  - PWM control
  - CTIMER global start
- Security configuration
  - Security control
  - Security attestation
- Reset control
  - Monitors and release resets to individual peripherals
- Device ID register

### 14.3 Functional description

The MRCC submodule provides on-chip modules their own dedicated MRCC bits for clock gating, reset control and configuration options. Generally, MRCC register contains a clock configuration ( $CC = \{MRCC\_GLB\_ACC[peripherals\ name], MRCC\_GLB\_CC[peripherals\ name]\}$ ) field for the module's clocks.

---

#### NOTE

Before a module can be used, its clocks must be enabled ( $CC \neq 00$ ) and it must be released from reset ( $MRCC\_GLB\_RST[peripherals\ name] \neq 1$ ). If a module is *not* released from reset ( $MRCC\_GLB\_RST[peripherals\ name] \neq 0$ ), an attempt to access a register within that module is terminated with a bus error.

If a module has a functional clock, its MRCC register may provide options for the clock source, selected by programming the mux select (MUX) field. The selected functional clock source can then be divided by programming the divider (DIV) field.

---

#### NOTE

Before configuring a functional clock, the module's clocks must be disabled ( $CC = 0b00$ ).

### 14.4 Signals

Table 73. SYSCON pin description

| Function | Type | Pin              | Description          |
|----------|------|------------------|----------------------|
| CLKOUT   | O    | P0_6, P3_6, P3_8 | CLKOUT clock output. |

### 14.5 Memory map and register definition

This section includes the SYSCON module memory map and detailed descriptions of all registers.

#### 14.5.1 SYSCON register descriptions

##### 14.5.1.1 SYSCON memory map

SYSCON base address: 4009\_1000h

| Offset | Register                                                          | Width<br>(In bits) | Access | Reset value |
|--------|-------------------------------------------------------------------|--------------------|--------|-------------|
| 200h   | AHB Matrix Remap Control (REMAP)                                  | 32                 | RW     | 0000_0000h  |
| 210h   | AHB Matrix Priority Control (AHBMATPRIO)                          | 32                 | RW     | 0000_0000h  |
| 23Ch   | Non-Secure CPU0 System Tick Calibration (CPU0NSTCKCAL)            | 32                 | RW     | 0000_0000h  |
| 248h   | NMI Source Select (NMISRC)                                        | 32                 | RW     | 0000_0000h  |
| 378h   | SLOW_CLK Clock Divider (SLOWCLKDIV)                               | 32                 | RW     | 0000_0000h  |
| 380h   | System Clock Divider (AHBCLKDIV)                                  | 32                 | RW     | 0000_0000h  |
| 3FCh   | Clock Configuration Unlock (CLKUNLOCK)                            | 32                 | RW     | 0000_0000h  |
| 400h   | NVM Control (NVM_CTRL)                                            | 32                 | RW     | 0002_0400h  |
| 404h   | ROM Wait State (ROMCR)                                            | 32                 | R      | 0000_0000h  |
| 80Ch   | CPU Status (CPUSTAT)                                              | 32                 | R      | 0000_0000h  |
| 824h   | LPCAC Control (LPCAC_CTRL)                                        | 32                 | RW     | 0000_0031h  |
| 938h   | PWM0 Submodule Control (PWM0SUBCTL)                               | 32                 | RW     | 0000_0000h  |
| 940h   | CTIMER Global Start Enable (CTIMERGLOBALSTARTEN)                  | 32                 | RW     | 0000_0000h  |
| 944h   | RAM Control (RAM_CTRL)                                            | 32                 | RW     | 0000_0001h  |
| B60h   | Gray to Binary Converter Gray Code [31:0] (GRAY_CODE_LSB)         | 32                 | RW     | 0000_0000h  |
| B64h   | Gray to Binary Converter Gray Code [41:32] (GRAY_CODE_MSB)        | 32                 | RW     | 0000_0000h  |
| B68h   | Gray to Binary Converter Binary Code [31:0] (BINARY_CODE_LSB)     | 32                 | R      | 0000_0000h  |
| B6Ch   | Gray to Binary Converter Binary Code [41:32]<br>(BINARY_CODE_MSB) | 32                 | R      | 0000_0000h  |
| E40h   | OVP_PAD_STATE (OVP_PAD_STATE)                                     | 32                 | R      | See section |
| E44h   | PROBE_STATE (PROBE_STATE)                                         | 32                 | R      | See section |
| E48h   | FT_STATE_A (FT_STATE_A)                                           | 32                 | R      | See section |
| E4Ch   | ROP State Register (ROP_STATE)                                    | 32                 | R      | See section |
| E58h   | RAM XEN Control (SRAM_XEN)                                        | 32                 | RW     | 0000_0000h  |
| E5Ch   | RAM XEN Control (Duplicate) (SRAM_XEN_DP)                         | 32                 | RW     | 0000_0000h  |
| E80h   | Life Cycle State Register (ELS OTP LC STATE)                      | 32                 | R      | See section |
| E84h   | Life Cycle State Register (Duplicate) (ELS OTP LC STATE DP)       | 32                 | R      | See section |
| FA0h   | Control Write Access to Security (DEBUG_LOCK_EN)                  | 32                 | RW     | 0000_000Ah  |
| FA4h   | Cortex Debug Features Control (DEBUG_FEATURES)                    | 32                 | RW     | See section |
| FA8h   | Cortex Debug Features Control (Duplicate)<br>(DEBUG_FEATURES_DP)  | 32                 | RW     | See section |
| FB4h   | CPU0 Software Debug Access (SWD_ACCESS_CPU0)                      | 32                 | RW     | 0000_0000h  |

Table continues on the next page...

*Table continued from the previous page...*

| Offset | Register                                        | Width<br>(In bits) | Access | Reset value                 |
|--------|-------------------------------------------------|--------------------|--------|-----------------------------|
| FC0h   | Debug Authentication BEACON (DEBUG_AUTH_BEACON) | 32                 | RW     | 0000_0000h                  |
| FF0h   | JTAG Chip ID (JTAG_ID)                          | 32                 | R      | 0726_602Bh                  |
| FF4h   | Device Type (DEVICE_TYPE)                       | 32                 | R      | <a href="#">See section</a> |
| FF8h   | Device ID (DEVICE_ID0)                          | 32                 | R      | <a href="#">See section</a> |
| FFCh   | Chip Revision ID and Number (DIEID)             | 32                 | R      | 0055_F1A0h                  |

#### 14.5.1.2 AHB Matrix Remap Control (REMAP)

##### Offset

| Register | Offset |
|----------|--------|
| REMAP    | 200h   |

##### Function

The Multilayer AHB Matrix remap for all masters, when they attempt to access the matrix slave port.

##### Diagram

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

##### Fields

| Field      | Function                                                                                                                                                                                                                                                                                              |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>LOCK | This 1-bit field provides a mechanism to limit writes to the this register to protect its contents. Once set, this bit remains asserted until a system reset.<br><br>0b - This register is not locked and can be altered.<br>1b - This register is locked and cannot be altered until a system reset. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                               |
|------------------|------------------------------------------------------------------------------------------------------------------------|
| 30-26<br>—       | Reserved Read value is undefined, only zero should be written.                                                         |
| 25-24<br>—       | Reserved Read value is undefined, only zero should be written.                                                         |
| 23-14<br>—       | Reserved Read value is undefined, only zero should be written.                                                         |
| 13-12<br>—       | Reserved Read value is undefined, only zero should be written.                                                         |
| 11-10<br>—       | Reserved Read value is undefined, only zero should be written.                                                         |
| 9-8<br>—         | Reserved Read value is undefined, only zero should be written.                                                         |
| 7-6<br>—         | Reserved Read value is undefined, only zero should be written.                                                         |
| 5-4<br>USB0      | RAMX0 address remap for USB0<br>00b - RAMX0: 0x04000000 - 0x04001fff<br>01b - RAMX0: same alias space as CPU0_SBUS     |
| 3-2<br>DMA0      | RAMX0 address remap for DMA0<br>00b - RAMX0: 0x04000000 - 0x04001fff<br>01b - RAMX0: same alias space as CPU0_SBUS     |
| 1-0<br>CPU0_SBUS | RAMX0 address remap for CPU System bus<br>00b - RAMX0: 0x04000000 - 0x04001fff<br>01b - RAMX0: 0x20006000 - 0x20007fff |

#### 14.5.1.3 AHB Matrix Priority Control (AHBMATPRIO)

##### Offset

| Register   | Offset |
|------------|--------|
| AHBMATPRIO | 210h   |

**Function**

The Multilayer AHB Matrix arbitrates between masters, when they attempt to access the same matrix slave port at the same time. The priority values are 3 = highest, 0 = lowest. When the priority is the same, the master with the lower master number is given priority.

**NOTE**

Be careful when modifying this register as improper settings can seriously degrade the performance.

**Diagram**

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

**Fields**

| Field       | Function                                                         |
|-------------|------------------------------------------------------------------|
| 31-30       | Reserved                                                         |
| —           |                                                                  |
| 29-28       | Reserved                                                         |
| —           |                                                                  |
| 27-26       | Reserved                                                         |
| —           |                                                                  |
| 25-24       | USB-FS bus master priority level                                 |
| USB_FS_ENET | 00b - level 0<br>01b - level 1<br>10b - level 2<br>11b - level 3 |
| 23-22       | Reserved                                                         |
| —           |                                                                  |
| 21-20       | Reserved                                                         |
| —           |                                                                  |
| 19-18       | Reserved                                                         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                      |
|------------------|---------------------------------------------------------------------------------------------------------------|
| —                |                                                                                                               |
| 17-16            | Reserved                                                                                                      |
| —                |                                                                                                               |
| 15-14            | Reserved                                                                                                      |
| —                |                                                                                                               |
| 13-12            | Reserved                                                                                                      |
| —                |                                                                                                               |
| 11-10            | Reserved                                                                                                      |
| —                |                                                                                                               |
| 9-8<br>DMA0      | DMA0 controller bus master priority level<br>00b - level 0<br>01b - level 1<br>10b - level 2<br>11b - level 3 |
| 7-6              | Reserved Read value is undefined, only zero should be written.                                                |
| —                |                                                                                                               |
| 5-4              | Reserved Read value is undefined, only zero should be written.                                                |
| —                |                                                                                                               |
| 3-2<br>CPU0_SBUS | CPU0 S-AHB bus master priority level<br>00b - level 0<br>01b - level 1<br>10b - level 2<br>11b - level 3      |
| 1-0<br>CPU0_CBUS | CPU0 C-AHB bus master priority level<br>00b - level 0<br>01b - level 1<br>10b - level 2<br>11b - level 3      |

#### 14.5.1.4 Non-Secure CPU0 System Tick Calibration (CPU0NSTCKCAL)

##### Offset

| Register     | Offset |
|--------------|--------|
| CPU0NSTCKCAL | 23Ch   |

##### Function

The CPU0NSTCKCAL register allows software to set up a default value for the SYST\_CALIB register in the System Tick Timer of non-secure part of the CPU0.

##### Diagram



##### Fields

| Field         | Function                                                                                                                                             |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-26<br>—    | Reserved                                                                                                                                             |
| 25<br>NOREF   | Indicates whether the device provides a reference clock to the processor.<br>0b - Reference clock is provided<br>1b - No reference clock is provided |
| 24<br>SKEW    | Indicates whether the TENMS value is exact.<br>0b - TENMS value is exact<br>1b - TENMS value is not exact or not given                               |
| 23-0<br>TENMS | Reload value for 10 ms (100 Hz) timing, subject to system clock skew errors. If the value reads as zero, the calibration value is not known.         |

#### 14.5.1.5 NMI Source Select (NMISRC)

##### Offset

| Register | Offset |
|----------|--------|
| NMISRC   | 248h   |

##### Diagram



##### Fields

| Field           | Function                                                                                                         |
|-----------------|------------------------------------------------------------------------------------------------------------------|
| 31<br>NMIENCPU0 | Enables the Non-Maskable Interrupt (NMI) source selected by IRQCPU0.<br>0b - Disable.<br>1b - Enable.            |
| 30<br>—         | Reserved                                                                                                         |
| 29-16<br>—      | Reserved                                                                                                         |
| 15-8<br>—       | Reserved                                                                                                         |
| 7-0<br>IRQCPU0  | The IRQ number of the interrupt that acts as the Non-Maskable Interrupt (NMI) for CPU0, if enabled by NMIENCPU0. |

#### 14.5.1.6 SLOW\_CLK Clock Divider (SLOWCLKDIV)

##### Offset

| Register   | Offset |
|------------|--------|
| SLOWCLKDIV | 378h   |

**Diagram****Fields**

| Field        | Function                                                                                                                                                            |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br>0b - Divider clock is stable<br>1b - Clock frequency is not stable                                                                           |
| 30<br>HALT   | Halts the divider counter<br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                         |
| 29<br>RESET  | Resets the divider counter<br><br><b>NOTE</b><br>Limited to configure RESET bit when HALT bit is set to 1<br><br>0b - Divider is not reset<br>1b - Divider is reset |
| 28-0<br>—    | Reserved                                                                                                                                                            |

**14.5.1.7 System Clock Divider (AHBCLKDIV)****Offset**

| Register  | Offset |
|-----------|--------|
| AHBCLKDIV | 380h   |

**Diagram**

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

**Fields**

| Field        | Function                                                                                  |
|--------------|-------------------------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br>0b - Divider clock is stable<br>1b - Clock frequency is not stable |
| 30-8<br>—    | Reserved                                                                                  |
| 7-0<br>DIV   | Clock divider value<br>The divider value = (DIV + 1)                                      |

**14.5.1.8 Clock Configuration Unlock (CLKUNLOCK)****Offset**

| Register  | Offset |
|-----------|--------|
| CLKUNLOCK | 3FCh   |

**Function**

This register controls access to the clock select and divider configuration registers.

**Diagram**

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

**Fields**

| Field       | Function                                                                                                                                                                                                                                       |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-1        | Reserved                                                                                                                                                                                                                                       |
| —           |                                                                                                                                                                                                                                                |
| 0<br>UNLOCK | Controls clock configuration registers access (for example, MRCC_xxx_CLKDIV, MRCC_xxx_CLKSEL, MRCC_GLB_xxx)<br><br>0b - Updates are allowed to all clock configuration registers<br><br>1b - Freezes all clock configuration registers update. |

**14.5.1.9 NVM Control (NVM\_CTRL)****Offset**

| Register | Offset |
|----------|--------|
| NVM_CTRL | 400h   |

**Diagram**

| Bits  | 31       | 30 | 29 | 28 | 27             | 26           | 25       | 24 | 23 | 22       | 21 | 20 | 19             | 18             | 17 | 16                               |
|-------|----------|----|----|----|----------------|--------------|----------|----|----|----------|----|----|----------------|----------------|----|----------------------------------|
| R     | Reserved |    |    |    |                |              |          |    |    |          |    |    |                |                |    | DIS_M<br>BE...<br>DIS_M<br>BE... |
| W     | 0        | 0  | 0  | 0  | 0              | 0            | 0        | 0  | 0  | 0        | 0  | 0  | 0              | 0              | 1  | 0                                |
| Reset | 0        | 0  | 0  | 0  | 0              | 0            | 0        | 0  | 0  | 0        | 0  | 0  | 0              | 0              | 1  | 0                                |
| Bits  | 15       | 14 | 13 | 12 | 11             | 10           | 9        | 8  | 7  | 6        | 5  | 4  | 3              | 2              | 1  | 0                                |
| R     | Reserved |    |    |    | FLASH<br>_S... | Reserv<br>ed | Reserved |    |    | Reserved |    |    | DIS_D<br>AT... | DIS_F<br>LA... |    |                                  |
| W     | 0        | 0  | 0  | 0  | 0              | 1            | 0        | 0  | 0  | 0        | 0  | 0  | 0              | 0              | 0  | 0                                |
| Reset | 0        | 0  | 0  | 0  | 0              | 1            | 0        | 0  | 0  | 0        | 0  | 0  | 0              | 0              | 0  | 0                                |

## Fields

| Field                            | Function                                                                                                                                                                                                                                                                                                                                                |
|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-18<br>—                       | Reserved                                                                                                                                                                                                                                                                                                                                                |
| 17<br><br>DIS_MBECC_E<br>RR_DATA | <p>Bus error on data multi-bit ECC error control</p> <p style="text-align: center;"><b>NOTE</b><br/>Set this field to 0 if you want to enable flash speculative</p> <p style="margin-left: 40px;">0b - Enables bus error on multi-bit ECC error for data<br/>1b - Disables bus error on multi-bit ECC error for data</p>                                |
| 16<br><br>DIS_MBECC_E<br>RR_INST | <p>Bus error on data multi-bit ECC error control</p> <p style="text-align: center;"><b>NOTE</b><br/>Set this field to 0 if you want to enable flash speculative</p> <p style="margin-left: 40px;">0b - Enables bus error on multi-bit ECC error for instruction<br/>1b - Disables bus error on multi-bit ECC error for instruction</p>                  |
| 15-11<br>—                       | Reserved                                                                                                                                                                                                                                                                                                                                                |
| 10<br><br>FLASH_STALL<br>_EN     | <p>FLASH stall on busy control</p> <p style="margin-left: 40px;">0b - No stall on FLASH busy<br/>1b - Stall on FLASH busy</p>                                                                                                                                                                                                                           |
| 9<br>—                           | Reserved Keep the default value.                                                                                                                                                                                                                                                                                                                        |
| 8-6<br>—                         | Reserved                                                                                                                                                                                                                                                                                                                                                |
| 5-2<br>—                         | Reserved                                                                                                                                                                                                                                                                                                                                                |
| 1<br><br>DIS_DATA_SP<br>EC       | <p>Flash data speculation control</p> <p style="text-align: center;"><b>NOTE</b><br/>If <a href="#">DIS_MBECC_ERR_DATA</a> and/or <a href="#">DIS_MBECC_ERR_INST</a> are set, then speculation will not be enabled, even if this bit is cleared.</p> <p style="margin-left: 40px;">0b - Enables data speculation<br/>1b - Disables data speculation</p> |
| 0                                | Flash speculation control                                                                                                                                                                                                                                                                                                                               |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field              | Function                                                                                                                                                                                                                                                                                    |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIS_FLASH_SP<br>EC | <p style="text-align: center;"><b>NOTE</b></p> <p>If <a href="#">DIS_MBECC_ERR_DATA</a> and/or <a href="#">DIS_MBECC_ERR_INST</a> are set, then speculation will not be enabled, even if this bit is cleared.</p> <p>0b - Enables flash speculation<br/>1b - Disables flash speculation</p> |

#### 14.5.1.10 ROM Wait State (ROMCR)

##### Offset

| Register | Offset |
|----------|--------|
| ROMCR    | 404h   |

##### Diagram



##### Fields

| Field      | Function |
|------------|----------|
| 31-28<br>— | Reserved |
| 27-0<br>—  | Reserved |

### 14.5.1.11 CPU Status (CPUSTAT)

#### Offset

| Register | Offset |
|----------|--------|
| CPUSTAT  | 80Ch   |

#### Diagram



#### Fields

| Field             | Function                                                                |
|-------------------|-------------------------------------------------------------------------|
| 31-4<br>—         | Reserved                                                                |
| 3<br>—            | Reserved                                                                |
| 2<br>CPU0LOCKUP   | CPU0 lockup state<br>0b - CPU is not in lockup<br>1b - CPU is in lockup |
| 1<br>—            | Reserved                                                                |
| 0<br>CPU0SLEEPING | CPU0 sleeping state<br>0b - CPU is not sleeping<br>1b - CPU is sleeping |

### 14.5.1.12 LPCAC Control (LPCAC\_CTRL)

#### Offset

| Register   | Offset |
|------------|--------|
| LPCAC_CTRL | 824h   |

#### Diagram



#### Fields

| Field              | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-10<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 9<br>—             | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 8<br>LPCAC_MEM_REQ | <p>Request LPCAC memories.</p> <p>0b - Configure shared memories RAMX1 as general memories.</p> <p>1b - Configure shared memories RAMX1 as LPCAC memories, write one lock until a system reset.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 7<br>LPCAC_XOM     | <p>LPCAC XOM(eXecute-Only-Memory) attribute control</p> <p>Controls if the instruction fetch attribute is used as part of the address input to the LPCAC. When XOM regions in the internal flash are not configured at the MBC, then this option should be disabled so that instructions and data can be stored within the same cache line. This provides the best cache efficiency for non-XOM applications. When XOM areas in the internal flash are configured at the MBC, then this bit must be set so that instructions and data are cached using separate lines within the LPCAC.</p> <p>0b - Disabled.</p> <p>1b - Enabled.</p> |
| 6                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

Table continues on the next page...

*Table continued from the previous page...*

| Field                   | Function                                                                                                                                                                 |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —                       |                                                                                                                                                                          |
| 5<br>LIM_LPCAC_W<br>TBF | Limit LPCAC Write Through Buffer.<br>0b - Write buffer enabled when transaction is bufferable.<br>1b - Write buffer enabled when transaction is cacheable and bufferable |
| 4<br>DIS_LPCAC_W<br>TBF | Disable LPCAC Write Through Buffer.<br>0b - Enables write through buffer<br>1b - Disables write through buffer                                                           |
| 3<br>—                  | Reserved                                                                                                                                                                 |
| 2<br>FRC_NO_ALLO<br>C   | Forces no allocation.<br>0b - Forces allocation<br>1b - Forces no allocation                                                                                             |
| 1<br>CLR_LPCAC          | Clears the cache function.<br>0b - Unclears the cache<br>1b - Clears the cache                                                                                           |
| 0<br>DIS_LPCAC          | Disables/enables the cache function.<br>0b - Enabled<br>1b - Disabled                                                                                                    |

#### 14.5.1.13 PWM0 Submodule Control (PWM0SUBCTL)

Offset

| Register   | Offset |
|------------|--------|
| PWM0SUBCTL | 938h   |

**Diagram**

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

**Fields**

| Field          | Function                                               |
|----------------|--------------------------------------------------------|
| 31-16<br>—     | Reserved                                               |
| 15-4<br>—      | Reserved                                               |
| 3-0<br>CLKn_EN | Enables PWM0 SUB Clockn<br>0b - Disable<br>1b - Enable |

**14.5.1.14 CTIMER Global Start Enable (CTIMERGLOBALSTARTEN)****Offset**

| Register          | Offset |
|-------------------|--------|
| CTIMERGLOBALSTART | 940h   |

**Function**

Refer to CTIMERn TCR.AGCEN

**Diagram**

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

**Fields**

| Field               | Function                                                          |
|---------------------|-------------------------------------------------------------------|
| 31-5<br>—           | Reserved                                                          |
| 4<br>—              | Reserved                                                          |
| 3<br>—              | Reserved                                                          |
| 2<br>CTIMER2_CLK_EN | Enables the CTIMER2 function clock<br>0b - Disable<br>1b - Enable |
| 1<br>CTIMER1_CLK_EN | Enables the CTIMER1 function clock<br>0b - Disable<br>1b - Enable |
| 0<br>CTIMER0_CLK_EN | Enables the CTIMER0 function clock<br>0b - Disable<br>1b - Enable |

**14.5.1.15 RAM Control (RAM\_CTRL)****Offset**

| Register | Offset |
|----------|--------|
| RAM_CTRL | 944h   |

**Diagram**

| Bits  | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23           | 22           | 21           | 20           | 19           | 18           | 17             | 16             |
|-------|----------|----|----|----|----|----|----|----|--------------|--------------|--------------|--------------|--------------|--------------|----------------|----------------|
| R     | Reserved |    |    |    |    |    |    |    | Reserv<br>ed | Reserv<br>ed | Reserv<br>ed | Reserv<br>ed | Reserv<br>ed | Reserv<br>ed | RAMX<br>_CG... | RAMA<br>_CG... |
| W     |          |    |    |    |    |    |    |    |              |              |              |              |              |              |                |                |
| Reset | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0            | 0            | 0            | 0            | 0            | 0            | 0              | 0              |
| Bits  | 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7            | 6            | 5            | 4            | 3            | 2            | 1              | 0              |
| R     | Reserved |    |    |    |    |    |    |    | Reserv<br>ed   | RAMA<br>_EC... |
| W     |          |    |    |    |    |    |    |    |              |              |              |              |              |              |                |                |
| Reset | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0            | 0            | 0            | 0            | 0            | 0            | 0              | 1              |

**Fields**

| Field                 | Function                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24                 | Reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| —                     |                                                                                                                                                                                                                                                                                                                                                                                               |
| 23                    | Reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| —                     |                                                                                                                                                                                                                                                                                                                                                                                               |
| 22                    | Reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| —                     |                                                                                                                                                                                                                                                                                                                                                                                               |
| 21                    | Reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| —                     |                                                                                                                                                                                                                                                                                                                                                                                               |
| 20                    | Reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| —                     |                                                                                                                                                                                                                                                                                                                                                                                               |
| 19                    | Reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| —                     |                                                                                                                                                                                                                                                                                                                                                                                               |
| 18                    | Reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| —                     |                                                                                                                                                                                                                                                                                                                                                                                               |
| 17                    | RAMX bank clock gating control                                                                                                                                                                                                                                                                                                                                                                |
| RAMX(CG_OV<br>ERRIDE) | 0b - Memory bank clock is gated automatically if no access more than 16 clock cycles<br>1b - Auto clock gating feature is disabled                                                                                                                                                                                                                                                            |
| 16                    | RAMA bank clock gating control, only available when RAMA_ECC_ENABLE = 0.                                                                                                                                                                                                                                                                                                                      |
| RAMA(CG_OV<br>ERRIDE) | 0b - Memory bank clock is gated automatically if no access more than 16 clock cycles. Auto-clockgating using bank_adapter gives a timeout counter for each bank. Once it expires upon no access per specified width (16 cycles), then clock to the bank is stopped high and one cycle penalty will be incurred if a read is the first access after the break). A write will incur no penalty. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                     | Function                                                        |
|---------------------------|-----------------------------------------------------------------|
|                           | 1b - Auto clock gating feature is disabled                      |
| 15-8<br>—                 | Reserved                                                        |
| 7<br>—                    | Reserved                                                        |
| 6<br>—                    | Reserved                                                        |
| 5<br>—                    | Reserved                                                        |
| 4<br>—                    | Reserved                                                        |
| 3<br>—                    | Reserved                                                        |
| 2<br>—                    | Reserved                                                        |
| 1<br>—                    | Reserved                                                        |
| 0<br>RAMA_ECC_E<br>ENABLE | RAMA0 ECC enable<br>0b - ECC is disabled<br>1b - ECC is enabled |

#### 14.5.1.16 Gray to Binary Converter Gray Code [31:0] (GRAY\_CODE\_LSB)

##### Offset

| Register      | Offset |
|---------------|--------|
| GRAY_CODE_LSB | B60h   |

##### Function

The Gray Code LSB Input register (CODE\_GRAY\_LSB) contains the least-significant portion of the Gray code to be converted back to binary.

**Diagram**

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

**Fields**

| Field          | Function                                                                                |
|----------------|-----------------------------------------------------------------------------------------|
| 31-0           | Gray code [31:0]                                                                        |
| code_gray_31_0 | CODE_GRAY_LSB is the least-significant 32 bits of the 42-bit Gray code to be converted. |

**14.5.1.17 Gray to Binary Converter Gray Code [41:32] (GRAY\_CODE\_MSB)****Offset**

| Register      | Offset |
|---------------|--------|
| GRAY_CODE_MSB | B64h   |

**Function**

The Gray Code MSB Input register (CODE\_GRAY\_MSB) contains the most-significant portion of the Gray code to be converted back to binary.

**Diagram**

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

**Fields**

| Field                  | Function                                                                                                    |
|------------------------|-------------------------------------------------------------------------------------------------------------|
| 31-10<br>—             | Reserved                                                                                                    |
| 9-0<br>code_gray_41_32 | Gray code [41:32]<br>CODE_GRAY_MSB is the most-significant 10 bits of the 42-bit Gray code to be converted. |

**14.5.1.18 Gray to Binary Converter Binary Code [31:0] (BINARY\_CODE\_LSB)****Offset**

| Register        | Offset |
|-----------------|--------|
| BINARY_CODE_LSB | B68h   |

**Function**

The Binary Code LSB register (BINARY\_CODE\_LSB) contains the least-significant portion of the code converted from Gray to binary coding.

**Diagram****Fields**

| Field                 | Function                                                                                           |
|-----------------------|----------------------------------------------------------------------------------------------------|
| 31-0<br>code_bin_31_0 | Binary code [31:0]<br>code_bin_31_0 is the least-significant 32 bits of the 42-bit converted code. |

#### 14.5.1.19 Gray to Binary Converter Binary Code [41:32] (BINARY\_CODE\_MSB)

##### Offset

| Register        | Offset |
|-----------------|--------|
| BINARY_CODE_MSB | B6Ch   |

##### Function

The Binary Code MSB register (BINARY\_CODE\_MSB) contains the most-significant portion of the code converted from Gray to binary coding.

##### Diagram



##### Fields

| Field          | Function                                                                     |
|----------------|------------------------------------------------------------------------------|
| 31-10          | Reserved                                                                     |
| —              |                                                                              |
| 9-0            | Binary code [41:32]                                                          |
| code_bin_41_32 | code_bin_41_32 is the most-significant 10 bits of the 42-bit converted code. |

#### 14.5.1.20 OVP\_PAD\_STATE (OVP\_PAD\_STATE)

##### Offset

| Register      | Offset |
|---------------|--------|
| OVP_PAD_STATE | E40h   |

**Diagram**

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

**Fields**

| Field                     | Function      |
|---------------------------|---------------|
| 31-0<br>OVP_PAD_STA<br>TE | OVP_PAD_STATE |

**14.5.1.21 PROBE\_STATE (PROBE\_STATE)****Offset**

| Register    | Offset |
|-------------|--------|
| PROBE_STATE | E44h   |

**Diagram**

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

**Fields**

| Field       | Function    |
|-------------|-------------|
| 31-0        | PROBE_STATE |
| PROBE_STATE |             |

**14.5.1.22 FT\_STATE\_A (FT\_STATE\_A)****Offset**

| Register   | Offset |
|------------|--------|
| FT_STATE_A | E48h   |

**Diagram****Fields**

| Field      | Function   |
|------------|------------|
| 31-0       | FT_STATE_A |
| FT_STATE_A |            |

**14.5.1.23 ROP State Register (ROP\_STATE)****Offset**

| Register  | Offset |
|-----------|--------|
| ROP_STATE | E4Ch   |

**Function**

This register is written by Boot-ROM code and is only one-time write and locked down until a system reset.

**Diagram**

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

**Fields**

| Field             | Function  |
|-------------------|-----------|
| 31-0<br>ROP_STATE | ROP state |

**14.5.1.24 RAM XEN Control (SRAM\_XEN)****Offset**

| Register | Offset |
|----------|--------|
| SRAM_XEN | E58h   |

**Diagram**

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

**Fields**

| Field          | Function                                                                                                                                                                                                                                                                                           |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>LOCK     | This 1-bit field provides a mechanism to limit writes to the this register (and SRAM_XEN_DP) to protect its contents. Once set, this bit remains asserted until a system reset.<br><br>0b - This register is not locked and can be altered.<br>1b - This register is locked and cannot be altered. |
| 30-8<br>—      | Reserved                                                                                                                                                                                                                                                                                           |
| 7<br>—         | Reserved                                                                                                                                                                                                                                                                                           |
| 6<br>—         | Reserved                                                                                                                                                                                                                                                                                           |
| 5<br>—         | Reserved                                                                                                                                                                                                                                                                                           |
| 4<br>—         | Reserved                                                                                                                                                                                                                                                                                           |
| 3<br>RAMA1_XEN | RAMAx (excepts RAMA0) Execute permission control.<br><br>0b - Execute permission is disabled, R/W are enabled.<br>1b - Execute permission is enabled, R/W/X are enabled.                                                                                                                           |
| 2<br>RAMA0_XEN | RAMA0 Execute permission control.<br><br>0b - Execute permission is disabled, R/W are enabled.<br>1b - Execute permission is enabled, R/W/X are enabled.                                                                                                                                           |
| 1<br>RAMX1_XEN | RAMX1 Execute permission control.<br><br>0b - Execute permission is disabled, R/W are enabled.<br>1b - Execute permission is enabled, R/W/X are enabled.                                                                                                                                           |
| 0<br>RAMX0_XEN | RAMX0 Execute permission control.<br><br>0b - Execute permission is disabled, R/W are enabled.<br>1b - Execute permission is enabled, R/W/X are enabled.                                                                                                                                           |

**14.5.1.25 RAM XEN Control (Duplicate) (SRAM\_XEN\_DP)****Offset**

| Register    | Offset |
|-------------|--------|
| SRAM_XEN_DP | E5Ch   |

**Function**

Protected by GLIKEY CRTL\_0.WRITE\_INDEX[7:0]=2

**Diagram**

| Bits  | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23           | 22           | 21           | 20           | 19             | 18             | 17             | 16             |
|-------|----------|----|----|----|----|----|----|----|--------------|--------------|--------------|--------------|----------------|----------------|----------------|----------------|
| R     | Reserved |    |    |    |    |    |    |    |              |              |              |              |                |                |                |                |
| W     |          |    |    |    |    |    |    |    |              |              |              |              |                |                |                |                |
| Reset | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0            | 0            | 0            | 0            | 0              | 0              | 0              | 0              |
| Bits  | 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7            | 6            | 5            | 4            | 3              | 2              | 1              | 0              |
| R     | Reserved |    |    |    |    |    |    |    | Reserv<br>ed | Reserv<br>ed | Reserv<br>ed | Reserv<br>ed | RAMA<br>1_X... | RAMA<br>0_X... | RAMX<br>1_X... | RAMX<br>0_X... |
| W     |          |    |    |    |    |    |    |    | 0            | 0            | 0            | 0            | 0              | 0              | 0              | 0              |
| Reset | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0            | 0            | 0            | 0            | 0              | 0              | 0              | 0              |

**Fields**

| Field     | Function                            |
|-----------|-------------------------------------|
| 31-8      | Reserved                            |
| —         |                                     |
| 7         | Reserved                            |
| —         |                                     |
| 6         | Reserved                            |
| —         |                                     |
| 5         | Reserved                            |
| —         |                                     |
| 4         | Reserved                            |
| —         |                                     |
| 3         | Refer to SRAM_XEN for more details. |
| RAMA1_XEN |                                     |
| 2         | Refer to SRAM_XEN for more details. |
| RAMA0_XEN |                                     |
| 1         | Refer to SRAM_XEN for more details. |
| RAMX1_XEN |                                     |
| 0         | Refer to SRAM_XEN for more details. |
| RAMX0_XEN |                                     |

#### 14.5.1.26 Life Cycle State Register (ELS OTP LC STATE)

Offset

| Register         | Offset |
|------------------|--------|
| ELS OTP LC STATE | E80h   |

Diagram



Fields

| Field                   | Function             |
|-------------------------|----------------------|
| 31-8<br>—               | Reserved             |
| 7-0<br>OTP_LC_STAT<br>E | OTP life cycle state |

#### 14.5.1.27 Life Cycle State Register (Duplicate) (ELS OTP LC STATE DP)

Offset

| Register                | Offset |
|-------------------------|--------|
| ELS OTP LC STATE_D<br>P | E84h   |

**Diagram**

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

**Fields**

| Field                   | Function             |
|-------------------------|----------------------|
| 31-8                    | Reserved             |
| —                       |                      |
| 7-0<br>OTP_LC_STAT_E_DP | OTP life cycle state |

**14.5.1.28 Control Write Access to Security (DEBUG\_LOCK\_EN)****Offset**

| Register      | Offset |
|---------------|--------|
| DEBUG_LOCK_EN | FA0h   |

**Function**

Controls write access to the SWD\_ACCESS\_CPU0, DEBUG\_FEATURES, DEBUG\_FEATURES\_DP and DEBUG\_AUTH\_BEACON registers

**Diagram**

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

**Fields**

| Field           | Function                                                                                                                                                                                                                                                                                              |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4<br>—       | Reserved                                                                                                                                                                                                                                                                                              |
| 3-0<br>LOCK_ALL | Controls write access to the security registers<br>Controls write access to the SWD_ACCESS_CPU0, DEBUG_FEATURES, DEBUG_FEATURES_DP and DEBUG_AUTH_BEACON registers<br><br>0000b - Any other value than b1010: disables write access to all registers<br>1010b - Enables write access to all registers |

**14.5.1.29 Cortex Debug Features Control (DEBUG\_FEATURES)****Offset**

| Register       | Offset |
|----------------|--------|
| DEBUG_FEATURES | FA4h   |

**Function**

Cortex M33 (CPU0) debug features control.

— NOTE —  
Reset on PoR only

**Diagram****Fields**

| Field      | Function                              |
|------------|---------------------------------------|
| 31-14<br>— | Reserved                              |
| 3-0        | CPU0_NIDEN (R/W) and CPU0_DBGEN (R/W) |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field              | Function                                                                                                                                               |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13-12<br>—         | Reserved                                                                                                                                               |
| 11-8<br>—          | Reserved                                                                                                                                               |
| 7-6<br>—           | Reserved                                                                                                                                               |
| 5-4<br>—           | Reserved                                                                                                                                               |
| 3-2<br>CPU0_NIDEN  | CPU0 non-invasive debug control<br>Enables non-invasive debug for CPU0. Values not listed are reserved.<br>01b - Disables debug<br>10b - Enables debug |
| 1-0<br>CPU0_DBGGEN | CPU0 invasive debug control<br>Enables invasive debug for CPU0. Values not listed are reserved.<br>01b - Disables debug<br>10b - Enables debug         |

#### 14.5.1.30 Cortex Debug Features Control (Duplicate) (DEBUG\_FEATURES\_DP)

##### Offset

| Register          | Offset |
|-------------------|--------|
| DEBUG_FEATURES_DP | FA8h   |

##### Function

Cortex M33 (CPU0) debug features control.

**Diagram**

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

**Fields**

| Field              | Function                                                                                                                                                       |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-14<br>—         | Reserved                                                                                                                                                       |
| 13-12<br>—         | Reserved                                                                                                                                                       |
| 11-8<br>—          | Reserved                                                                                                                                                       |
| 7-6<br>—           | Reserved                                                                                                                                                       |
| 5-4<br>—           | Reserved                                                                                                                                                       |
| 3-2<br>CPU0_NIDEN  | CPU0 non-invasive debug control<br><br>Enables non-invasive debug for CPU0. Values not listed are reserved.<br><br>01b - Disables debug<br>10b - Enables debug |
| 1-0<br>CPU0_DBGGEN | CPU0 invasive debug control<br><br>Enables invasive debug for CPU0. Values not listed are reserved.<br><br>01b - Disables debug<br>10b - Enables debug         |

#### 14.5.1.31 CPU0 Software Debug Access (SWD\_ACCESS\_CPU0)

##### Offset

| Register        | Offset |
|-----------------|--------|
| SWD_ACCESS_CPU0 | FB4h   |

##### Function

This register is used by ROM during DEBUG authentication mechanism to enable debug access port for CPU0. write once only.

— NOTE —  
Reset on PoR only

##### Diagram



##### Fields

| Field    | Function                                                                                                                                                                                                                           |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0     | CPU0 SWD-AP: 0x12345678                                                                                                                                                                                                            |
| SEC_CODE | 0000_0000_0000_0000_0000_0000_0000b - CPU0 DAP is not allowed. Reading back register is read as 0x5.<br>0001_0010_0011_0100_0101_0110_0111_1000b - Value to write to enable CPU0 SWD access. Reading back register is read as 0xA. |

#### 14.5.1.32 Debug Authentication BEACON (DEBUG\_AUTH\_BEACON)

##### Offset

| Register          | Offset |
|-------------------|--------|
| DEBUG_AUTH_BEACON | FC0h   |

**Function**

This register protected by security. ROM sets register (read-only) with value received in debug credentials before passing control to the user code. This can be used to extend debug authentication control for the customer application.

**NOTE**  
Reset on PoR only

**Diagram**

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

**Fields**

| Field          | Function                                                                                                                                      |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>BEACON | Sets by the debug authentication code in ROM to pass the debug beacons (Credential Beacon and Authentication Beacon) to the application code. |

**14.5.1.33 JTAG Chip ID (JTAG\_ID)****Offset**

| Register | Offset |
|----------|--------|
| JTAG_ID  | FF0h   |

**Diagram**

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

**Fields**

| Field   | Function                |
|---------|-------------------------|
| 31-0    | Indicates the device ID |
| JTAG_ID |                         |

**14.5.1.34 Device Type (DEVICE\_TYPE)****Offset**

| Register    | Offset |
|-------------|--------|
| DEVICE_TYPE | FF4h   |

**Diagram****Fields**

| Field       | Function               |
|-------------|------------------------|
| 31-0        | Indicates DEVICE TYPE. |
| DEVICE_TYPE |                        |

**14.5.1.35 Device ID (DEVICE\_ID0)****Offset**

| Register   | Offset |
|------------|--------|
| DEVICE_ID0 | FF8h   |

**Function**

This register contains the device ID.

**Diagram**

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

**Fields**

| Field             | Function                                                                                                                                                                    |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-28             | Reserved                                                                                                                                                                    |
| —                 |                                                                                                                                                                             |
| 27-24<br>SECURITY | 0101b - Secure version.<br>1010b - Non secure version.                                                                                                                      |
| 23-20             | Reserved                                                                                                                                                                    |
| —                 |                                                                                                                                                                             |
| 19-8              | Reserved                                                                                                                                                                    |
| —                 |                                                                                                                                                                             |
| 7-4<br>FLASH_SIZE | Chip FLASH Size<br>0000b - 32KB.<br>0001b - 64KB.<br>0010b - 128KB.<br>0011b - 256KB.<br>0100b - 512KB.<br>0101b - 768KB.<br>0110b - 1MB.<br>0111b - 1.5MB.<br>1000b - 2MB. |
| 3-0<br>RAM_SIZE   | Chip RAM Size<br>0000b - 8KB.<br>0001b - 16KB.                                                                                                                              |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                      |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 0010b - 32KB.<br>0011b - 64KB.<br>0100b - 96KB.<br>0101b - 128KB.<br>0110b - 160KB.<br>0111b - 192KB.<br>1000b - 256KB.<br>1001b - 288KB.<br>1010b - 352KB.<br>1011b - 512KB. |

#### 14.5.1.36 Chip Revision ID and Number (DIEID)

##### Offset

| Register | Offset |
|----------|--------|
| DIEID    | FFCh   |

##### Function

This register contains the chip number and revision.

##### Diagram



##### Fields

| Field | Function |
|-------|----------|
| 31-28 | Reserved |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                         | Function            |
|-------------------------------|---------------------|
| —                             |                     |
| 27-8<br>MCO_NUM_IN_<br>DIE_ID | Chip number         |
| 7-4<br>MAJOR_REVIS<br>ION     | Chip major revision |
| 3-0<br>MINOR_REVISI<br>ON     | Chip minor revision |

## 14.5.2 MRCC register descriptions

### 14.5.2.1 MRCC memory map

MRCC0 base address: 4009\_1000h

| Offset | Register                                                  | Width<br>(in bits) | Access | Reset value |
|--------|-----------------------------------------------------------|--------------------|--------|-------------|
| 0h     | Peripheral Reset Control 0 (MRCC_GLB_RST0)                | 32                 | RW     | 0000_0000h  |
| 4h     | Peripheral Reset Control Set 0 (MRCC_GLB_RST0_SET)        | 32                 | W      | 0000_0000h  |
| 8h     | Peripheral Reset Control Clear 0 (MRCC_GLB_RST0_CLR)      | 32                 | W      | 0000_0000h  |
| 10h    | Peripheral Reset Control 1 (MRCC_GLB_RST1)                | 32                 | RW     | 0000_0000h  |
| 14h    | Peripheral Reset Control Set 1 (MRCC_GLB_RST1_SET)        | 32                 | W      | 0000_0000h  |
| 18h    | Peripheral Reset Control Clear 1 (MRCC_GLB_RST1_CLR)      | 32                 | W      | 0000_0000h  |
| 40h    | AHB Clock Control 0 (MRCC_GLB_CC0)                        | 32                 | RW     | 0000_0000h  |
| 44h    | AHB Clock Control Set 0 (MRCC_GLB_CC0_SET)                | 32                 | W      | 0000_0000h  |
| 48h    | AHB Clock Control Clear 0 (MRCC_GLB_CC0_CLR)              | 32                 | W      | 0000_0000h  |
| 50h    | AHB Clock Control 1 (MRCC_GLB_CC1)                        | 32                 | RW     | 0000_0000h  |
| 54h    | AHB Clock Control Set 1 (MRCC_GLB_CC1_SET)                | 32                 | W      | 0000_0000h  |
| 58h    | AHB Clock Control Clear 1 (MRCC_GLB_CC1_CLR)              | 32                 | W      | 0000_0000h  |
| 80h    | Control Automatic Clock Gating 0 (MRCC_GLB_ACC0)          | 32                 | RW     | 0000_0080h  |
| 84h    | Control Automatic Clock Gating 1 (MRCC_GLB_ACC1)          | 32                 | RW     | 0000_0210h  |
| A0h    | I3C0_FCLK clock selection control (MRCC_I3C0_FCLK_CLKSEL) | 32                 | RW     | 0000_0007h  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset          | Register                                                | Width<br>(In bits) | Access | Reset value |
|-----------------|---------------------------------------------------------|--------------------|--------|-------------|
| A4h             | I3C0_FCLK clock divider control (MRCC_I3C0_FCLK_CLKDIV) | 32                 | RW     | 4000_0000h  |
| A8h             | CTIMER0 clock selection control (MRCC_CTIMER0_CLKSEL)   | 32                 | RW     | 0000_0007h  |
| ACh             | CTIMER0 clock divider control (MRCC_CTIMER0_CLKDIV)     | 32                 | RW     | 4000_0000h  |
| B0h             | CTIMER1 clock selection control (MRCC_CTIMER1_CLKSEL)   | 32                 | RW     | 0000_0007h  |
| B4h             | CTIMER1 clock divider control (MRCC_CTIMER1_CLKDIV)     | 32                 | RW     | 4000_0000h  |
| B8h             | CTIMER2 clock selection control (MRCC_CTIMER2_CLKSEL)   | 32                 | RW     | 0000_0007h  |
| BCh             | CTIMER2 clock divider control (MRCC_CTIMER2_CLKDIV)     | 32                 | RW     | 4000_0000h  |
| C4h             | WWDT0 clock divider control (MRCC_WWDT0_CLKDIV)         | 32                 | RW     | 0000_0000h  |
| C8h             | LPI2C0 clock selection control (MRCC_LPI2C0_CLKSEL)     | 32                 | RW     | 0000_0007h  |
| CCh             | LPI2C0 clock divider control (MRCC_LPI2C0_CLKDIV)       | 32                 | RW     | 4000_0000h  |
| D0h             | LPSPI0 clock selection control (MRCC_LPSPI0_CLKSEL)     | 32                 | RW     | 0000_0007h  |
| D4h             | LPSPI0 clock divider control (MRCC_LPSPI0_CLKDIV)       | 32                 | RW     | 4000_0000h  |
| D8h             | LPSPI1 clock selection control (MRCC_LPSPI1_CLKSEL)     | 32                 | RW     | 0000_0007h  |
| DCh             | LPSPI1 clock divider control (MRCC_LPSPI1_CLKDIV)       | 32                 | RW     | 4000_0000h  |
| E0h             | LPUART0 clock selection control (MRCC_LPUART0_CLKSEL)   | 32                 | RW     | 0000_0007h  |
| E4h             | LPUART0 clock divider control (MRCC_LPUART0_CLKDIV)     | 32                 | RW     | 4000_0000h  |
| E8h             | LPUART1 clock selection control (MRCC_LPUART1_CLKSEL)   | 32                 | RW     | 0000_0007h  |
| EC <sub>h</sub> | LPUART1 clock divider control (MRCC_LPUART1_CLKDIV)     | 32                 | RW     | 4000_0000h  |
| F0h             | LPUART2 clock selection control (MRCC_LPUART2_CLKSEL)   | 32                 | RW     | 0000_0007h  |
| F4h             | LPUART2 clock divider control (MRCC_LPUART2_CLKDIV)     | 32                 | RW     | 4000_0000h  |
| F8h             | USB0 clock selection control (MRCC_USB0_CLKSEL)         | 32                 | RW     | 0000_0003h  |
| 100h            | LPTMR0 clock selection control (MRCC_LPTMR0_CLKSEL)     | 32                 | RW     | 0000_0007h  |
| 104h            | LPTMR0 clock divider control (MRCC_LPTMR0_CLKDIV)       | 32                 | RW     | 4000_0000h  |
| 108h            | OSTIMER0 clock selection control (MRCC_OSTIMER0_CLKSEL) | 32                 | RW     | 0000_0003h  |
| 110h            | ADC0 clock selection control (MRCC_ADC0_CLKSEL)         | 32                 | RW     | 0000_0007h  |
| 114h            | ADC0 clock divider control (MRCC_ADC0_CLKDIV)           | 32                 | RW     | 4000_0000h  |
| 11Ch            | CMP0_FUNC clock divider control (MRCC_CMP0_FUNC_CLKDIV) | 32                 | RW     | 0000_0000h  |
| 120h            | CMP0_RR clock selection control (MRCC_CMP0_RR_CLKSEL)   | 32                 | RW     | 0000_0007h  |
| 124h            | CMP0_RR clock divider control (MRCC_CMP0_RR_CLKDIV)     | 32                 | RW     | 4000_0000h  |
| 12Ch            | CMP1_FUNC clock divider control (MRCC_CMP1_FUNC_CLKDIV) | 32                 | RW     | 0000_0000h  |
| 130h            | CMP1_RR clock selection control (MRCC_CMP1_RR_CLKSEL)   | 32                 | RW     | 0000_0007h  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset | Register                                                  | Width<br>(In bits) | Access | Reset value |
|--------|-----------------------------------------------------------|--------------------|--------|-------------|
| 134h   | CMP1_RR clock divider control (MRCC_CMP1_RR_CLKDIV)       | 32                 | RW     | 4000_0000h  |
| 138h   | DBG_TRACE clock selection control (MRCC_DBG_TRACE_CLKSEL) | 32                 | RW     | 0000_0000h  |
| 13Ch   | DBG_TRACE clock divider control (MRCC_DBG_TRACE_CLKDIV)   | 32                 | RW     | 0000_0000h  |
| 140h   | CLKOUT clock selection control (MRCC_CLKOUT_CLKSEL)       | 32                 | RW     | 0000_0007h  |
| 144h   | CLKOUT clock divider control (MRCC_CLKOUT_CLKDIV)         | 32                 | RW     | 4000_0000h  |
| 148h   | SYSTICK clock selection control (MRCC_SYSTICK_CLKSEL)     | 32                 | RW     | 0000_0003h  |
| 14Ch   | SYSTICK clock divider control (MRCC_SYSTICK_CLKDIV)       | 32                 | RW     | 4000_0000h  |
| 154h   | FRO_HF_DIV clock divider control (MRCC_FRO_HF_DIV_CLKDIV) | 32                 | RW     | 0000_0000h  |

#### 14.5.2.2 Peripheral Reset Control 0 (MRCC\_GLB\_RST0)

##### Offset

| Register      | Offset |
|---------------|--------|
| MRCC_GLB_RST0 | 0h     |

##### Diagram

| Bits  | 31       | 30    | 29    | 28   | 27       | 26   | 25       | 24       | 23       | 22     | 21      | 20      | 19      | 18      | 17     | 16         |
|-------|----------|-------|-------|------|----------|------|----------|----------|----------|--------|---------|---------|---------|---------|--------|------------|
| R     | PORT2    | PORT1 | PORT0 | CMP1 | Reserved | ADC0 | OSTIMER0 | FLEXPWM0 | QDC0     | USB0   | LPUART2 | LPUART1 | LPUART0 | LPSPI1  | LPSPI0 | LPI2C0     |
| W     | 2        | 1     | 0     |      | 0        | 0    | 0        | 0        | 0        | 0      | 0       | 0       | 0       | 0       | 0      | 0          |
| Reset | 0        | 0     | 0     | 0    | 0        | 0    | 0        | 0        | 0        | 0      | 0       | 0       | 0       | 0       | 0      | 0          |
| Bits  | 15       | 14    | 13    | 12   | 11       | 10   | 9        | 8        | 7        | 6      | 5       | 4       | 3       | 2       | 1      | 0          |
| R     | Reserved |       |       | ERM  | EIM      | CRC  | AOI0     | DMA      | Reserved | UTICK0 | FREQME  | CTIMER2 | CTIMER1 | CTIMER0 | I3C0   | INPUTMU... |
| W     | 0        | 0     | 0     | 0    | 0        | 0    | 0        | 0        | 0        | 0      | 0       | 0       | 0       | 0       | 0      | 0          |
| Reset | 0        | 0     | 0     | 0    | 0        | 0    | 0        | 0        | 0        | 0      | 0       | 0       | 0       | 0       | 0      | 0          |

##### Fields

| Field       | Function                                                                   |
|-------------|----------------------------------------------------------------------------|
| 31<br>PORT2 | 0b - Peripheral is held in reset<br>1b - Peripheral is released from reset |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                               |
|----------------|----------------------------------------------------------------------------------------|
| 30<br>PORT1    | PORT1<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset    |
| 29<br>PORT0    | PORT0<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset    |
| 28<br>CMP1     | CMP1<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset     |
| 27<br>—        | reserved<br>reserved                                                                   |
| 26<br>ADC0     | ADC0<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset     |
| 25<br>OSTIMER0 | OSTIMER0<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset |
| 24<br>FLEXPWM0 | FLEXPWM0<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset |
| 23<br>QDC0     | QDC0<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset     |
| 22<br>USB0     | USB0<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset     |
| 21<br>LPUART2  | LPUART2<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset  |
| 20<br>LPUART1  | LPUART1<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                              |
|---------------|---------------------------------------------------------------------------------------|
| 19<br>LPUART0 | LPUART0<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset |
| 18<br>LPSPI1  | LPSPI1<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset  |
| 17<br>LPSPI0  | LPSPI0<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset  |
| 16<br>LPI2C0  | LPI2C0<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset  |
| 15-13<br>—    | reserved<br>reserved                                                                  |
| 12<br>ERM     | ERM<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset     |
| 11<br>EIM     | EIM<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset     |
| 10<br>CRC     | CRC<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset     |
| 9<br>AOI0     | AOI0<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset    |
| 8<br>DMA      | DMA<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset     |
| 7<br>—        | reserved<br>reserved                                                                  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                |
|----------------|-----------------------------------------------------------------------------------------|
| 6<br>UTICK0    | UTICK0<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset    |
| 5<br>FREQME    | FREQME<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset    |
| 4<br>CTIMER2   | CTIMER2<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset   |
| 3<br>CTIMER1   | CTIMER1<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset   |
| 2<br>CTIMER0   | CTIMER0<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset   |
| 1<br>I3C0      | I3C0<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset      |
| 0<br>INPUTMUX0 | INPUTMUX0<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset |

#### 14.5.2.3 Peripheral Reset Control Set n (MRCC\_GLB\_RST0\_SET - MRCC\_GLB\_RST1\_SET)

##### Offset

| Register          | Offset |
|-------------------|--------|
| MRCC_GLB_RST0_SET | 4h     |
| MRCC_GLB_RST1_SET | 14h    |

##### Function

Writing a 1 to a bit position in a write-only MRCC\_GLB\_RSTn\_SET register sets the corresponding position in MRCC\_GLB\_RSTn.

**Diagram**

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

**Fields**

| Field | Function                                                            |
|-------|---------------------------------------------------------------------|
| 31-0  | Data array value, refer to corresponding position in MRCC_GLB_RSTn. |
| DATA  |                                                                     |

**14.5.2.4 Peripheral Reset Control Clear n (MRCC\_GLB\_RST0\_CLR - MRCC\_GLB\_RST1\_CLR)****Offset**

| Register          | Offset |
|-------------------|--------|
| MRCC_GLB_RST0_CLR | 8h     |
| MRCC_GLB_RST1_CLR | 18h    |

**Function**

Writing a 1 to a bit position in a write-only MRCC\_GLB\_RSTn\_CLR register clears the corresponding position in MRCC\_GLB\_RSTn.

**Diagram**

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

**Fields**

| Field        | Function                                                            |
|--------------|---------------------------------------------------------------------|
| 31-0<br>DATA | Data array value, refer to corresponding position in MRCC_GLB_RSTn. |

**14.5.2.5 Peripheral Reset Control 1 (MRCC\_GLB\_RST1)****Offset**

| Register      | Offset |
|---------------|--------|
| MRCC_GLB_RST1 | 10h    |

**Diagram****Fields**

| Field      | Function                                                                            |
|------------|-------------------------------------------------------------------------------------|
| 31-9<br>—  | reserved<br>reserved                                                                |
| 8<br>GPIO3 | GPIO3<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset |
| 7<br>GPIO2 | GPIO2<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset |
| 6<br>GPIO1 | GPIO1<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                            |
|------------|-------------------------------------------------------------------------------------|
| 5<br>GPIO0 | GPIO0<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset |
| 4-1<br>—   | Reserved                                                                            |
| 0<br>PORT3 | PORT3<br>0b - Peripheral is held in reset<br>1b - Peripheral is released from reset |

#### 14.5.2.6 AHB Clock Control 0 (MRCC\_GLB\_CC0)

##### Offset

| Register     | Offset |
|--------------|--------|
| MRCC_GLB_CC0 | 40h    |

##### Function

Both MRCC\_GLB\_CCx and MRCC\_GLB\_ACCx are used to control modules' clocks, see [Application information](#) for usage.

##### Diagram

| Bits  | 31       | 30    | 29    | 28   | 27   | 26   | 25       | 24       | 23    | 22     | 21      | 20      | 19      | 18      | 17     | 16         |
|-------|----------|-------|-------|------|------|------|----------|----------|-------|--------|---------|---------|---------|---------|--------|------------|
| R     | PORT2    | PORT1 | PORT0 | CMP1 | CMP0 | ADCO | OSTIMER0 | FLEXPWM0 | QDC0  | USB0   | LPUART2 | LPUART1 | LPUART0 | LPSPI1  | LPSPI0 | LPI2C0     |
| W     | 2        | 1     | 0     |      |      |      |          |          |       |        |         |         |         |         |        |            |
| Reset | 0        | 0     | 0     | 0    | 0    | 0    | 0        | 0        | 0     | 0      | 0       | 0       | 0       | 0       | 0      | 0          |
| Bits  | 15       | 14    | 13    | 12   | 11   | 10   | 9        | 8        | 7     | 6      | 5       | 4       | 3       | 2       | 1      | 0          |
| R     | Reserved |       |       | ERM  | EIM  | CRC  | AOI0     | DMA      | WWDT0 | UTICK0 | FREQME  | CTIMER2 | CTIMER1 | CTIMER0 | I3C0   | INPUTMU... |
| W     | 0        | 0     | 0     | 0    | 0    | 0    | 0        | 0        | 0     | 0      | 0       | 0       | 0       | 0       | 0      | 0          |
| Reset | 0        | 0     | 0     | 0    | 0    | 0    | 0        | 0        | 0     | 0      | 0       | 0       | 0       | 0       | 0      | 0          |

##### Fields

| Field       | Function                                   |
|-------------|--------------------------------------------|
| 31<br>PORT2 | PORT2<br>0b - Peripheral clock is disabled |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                          |
|----------------|-----------------------------------------------------------------------------------|
|                | 1b - Peripheral clock is enabled                                                  |
| 30<br>PORT1    | PORT1<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled    |
| 29<br>PORT0    | PORT0<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled    |
| 28<br>CMP1     | CMP1<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled     |
| 27<br>CMP0     | CMP0<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled     |
| 26<br>ADC0     | ADC0<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled     |
| 25<br>OSTIMER0 | OSTIMER0<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled |
| 24<br>FLEXPWM0 | FLEXPWM0<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled |
| 23<br>QDC0     | QDC0<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled     |
| 22<br>USB0     | USB0<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled     |
| 21<br>LPUART2  | LPUART2<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                         |
|---------------|----------------------------------------------------------------------------------|
| 20<br>LPUART1 | LPUART1<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled |
| 19<br>LPUART0 | LPUART0<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled |
| 18<br>LP SPI1 | LP SPI1<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled |
| 17<br>LP SPI0 | LP SPI0<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled |
| 16<br>LPI2C0  | LPI2C0<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled  |
| 15-13<br>—    | reserved<br>reserved                                                             |
| 12<br>ERM     | ERM<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled     |
| 11<br>EIM     | EIM<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled     |
| 10<br>CRC     | CRC<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled     |
| 9<br>AOI0     | AOI0<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled    |
| 8<br>DMA      | DMA<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                           |
|----------------|------------------------------------------------------------------------------------|
| 7<br>WWDT0     | WWDT0<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled     |
| 6<br>UTICK0    | UTICK0<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled    |
| 5<br>FREQME    | FREQME<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled    |
| 4<br>CTIMER2   | CTIMER2<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled   |
| 3<br>CTIMER1   | CTIMER1<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled   |
| 2<br>CTIMER0   | CTIMER0<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled   |
| 1<br>I3C0      | I3C0<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled      |
| 0<br>INPUTMUX0 | INPUTMUX0<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled |

#### 14.5.2.7 AHB Clock Control Set n (MRCC\_GLB\_CC0\_SET - MRCC\_GLB\_CC1\_SET)

##### Offset

| Register         | Offset |
|------------------|--------|
| MRCC_GLB_CC0_SET | 44h    |
| MRCC_GLB_CC1_SET | 54h    |

**Function**

Writing a 1 to a bit position in a write-only MRCC\_GLB\_CCn\_SET register sets the corresponding position in MRCC\_GLB\_CCn.

**Diagram**

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

**Fields**

| Field | Function                                                           |
|-------|--------------------------------------------------------------------|
| 31-0  | Data array value, refer to corresponding position in MRCC_GLB_CCn. |

**14.5.2.8 AHB Clock Control Clear n (MRCC\_GLB\_CC0\_CLR - MRCC\_GLB\_CC1\_CLR)****Offset**

| Register         | Offset |
|------------------|--------|
| MRCC_GLB_CC0_CLR | 48h    |
| MRCC_GLB_CC1_CLR | 58h    |

**Function**

Writing a 1 to a bit position in a write-only MRCC\_GLB\_CCn\_CLR register clears the corresponding position in MRCC\_GLB\_CCn.

**Diagram**

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

**Fields**

| Field | Function                                                           |
|-------|--------------------------------------------------------------------|
| 31-0  | Data array value, refer to corresponding position in MRCC_GLB_CCn. |
| DATA  |                                                                    |

**14.5.2.9 AHB Clock Control 1 (MRCC\_GLB\_CC1)****Offset**

| Register     | Offset |
|--------------|--------|
| MRCC_GLB_CC1 | 50h    |

**Diagram**

| Bits  | 31       | 30 | 29 | 28 | 27 | 26        | 25 | 24    | 23 | 22    | 21 | 20    | 19 | 18       | 17 | 16        |  |
|-------|----------|----|----|----|----|-----------|----|-------|----|-------|----|-------|----|----------|----|-----------|--|
| R     |          |    |    |    |    |           |    |       |    |       |    |       |    |          |    |           |  |
| W     | Reserved |    |    |    |    |           |    |       |    |       |    |       |    |          |    |           |  |
| Reset | 0        | 0  | 0  | 0  | 0  | 0         | 0  | 0     | 0  | 0     | 0  | 0     | 0  | 0        | 0  | 0         |  |
| Bits  | 15       | 14 | 13 | 12 | 11 | 10        | 9  | 8     | 7  | 6     | 5  | 4     | 3  | 2        | 1  | 0         |  |
| R     |          |    |    |    |    | ROMC<br>P |    | GPIO3 |    | GPIO2 |    | GPIO1 |    | GPIO0    |    | RAMA      |  |
| W     | Reserved |    |    |    |    |           |    |       |    |       |    |       |    | Reserved |    | PORT<br>3 |  |
| Reset | 0        | 0  | 0  | 0  | 0  | 0         | 0  | 0     | 0  | 0     | 0  | 0     | 0  | 0        | 0  | 0         |  |

**Fields**

| Field | Function |
|-------|----------|
| 31-10 | reserved |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                       |
|------------|--------------------------------------------------------------------------------|
| —          | reserved                                                                       |
| 9<br>ROMCP | ROMCP<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled |
| 8<br>GPIO3 | GPIO3<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled |
| 7<br>GPIO2 | GPIO2<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled |
| 6<br>GPIO1 | GPIO1<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled |
| 5<br>GPIO0 | GPIO0<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled |
| 4<br>RAMA  | RAMA<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled  |
| 3-1<br>—   | Reserved                                                                       |
| 0<br>PORT3 | PORT3<br>0b - Peripheral clock is disabled<br>1b - Peripheral clock is enabled |

#### 14.5.2.10 Control Automatic Clock Gating 0 (MRCC\_GLB\_ACC0)

##### Offset

| Register      | Offset |
|---------------|--------|
| MRCC_GLB_ACC0 | 80h    |

##### Function

Both MRCC\_GLB\_CCx and MRCC\_GLB\_ACCx are used to control modules' clocks, see [Application information](#) for usage.

**Diagram**

| Bits  | 31        | 30        | 29        | 28   | 27   | 26   | 25           | 24           | 23    | 22     | 21          | 20          | 19          | 18         | 17         | 16         |
|-------|-----------|-----------|-----------|------|------|------|--------------|--------------|-------|--------|-------------|-------------|-------------|------------|------------|------------|
| R     | PORT<br>2 | PORT<br>1 | PORT<br>0 | CMP1 | CMP0 | ADC0 | OSTIM<br>ER0 | FLEXP<br>WM0 | QDC0  | USB0   | LPUA<br>RT2 | LPUA<br>RT1 | LPUA<br>RT0 | LPSPI<br>1 | LPSPI<br>0 | LPI2C<br>0 |
| W     |           |           |           |      |      |      |              |              |       |        |             |             |             |            |            |            |
| Reset | 0         | 0         | 0         | 0    | 0    | 0    | 0            | 0            | 0     | 0      | 0           | 0           | 0           | 0          | 0          | 0          |
| Bits  | 15        | 14        | 13        | 12   | 11   | 10   | 9            | 8            | 7     | 6      | 5           | 4           | 3           | 2          | 1          | 0          |
| R     |           |           |           | ERM  | EIM  | CRC  | AOI0         | DMA          | WWDT0 | UTICK0 | FREQME      | CTIMER2     | CTIMER1     | CTIMER0    | I3C0       | INPUTMU... |
| W     |           |           |           | 0    | 0    | 0    | 0            | 0            | 1     | 0      | 0           | 0           | 0           | 0          | 0          | 0          |
| Reset | 0         | 0         | 0         | 0    | 0    | 0    | 0            | 0            | 1     | 0      | 0           | 0           | 0           | 0          | 0          | 0          |

**Fields**

| Field          | Function                                                                                      |
|----------------|-----------------------------------------------------------------------------------------------|
| 31<br>PORT2    | PORT2<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled    |
| 30<br>PORT1    | PORT1<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled    |
| 29<br>PORT0    | PORT0<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled    |
| 28<br>CMP1     | CMP1<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled     |
| 27<br>CMP0     | CMP0<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled     |
| 26<br>ADC0     | ADC0<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled     |
| 25<br>OSTIMER0 | OSTIMER0<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled |
| 24             | FLEXPWM0                                                                                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                     |
|---------------|----------------------------------------------------------------------------------------------|
| FLEXPWM0      | 0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled            |
| 23<br>QDC0    | QDC0<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled    |
| 22<br>USB0    | USB0<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled    |
| 21<br>LPUART2 | LPUART2<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled |
| 20<br>LPUART1 | LPUART1<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled |
| 19<br>LPUART0 | LPUART0<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled |
| 18<br>LPSPI1  | LPSPI1<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled  |
| 17<br>LPSPI0  | LPSPI0<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled  |
| 16<br>LPI2C0  | LPI2C0<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled  |
| 15-13<br>—    | Reserved                                                                                     |
| 12<br>ERM     | ERM<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                     |
|--------------|----------------------------------------------------------------------------------------------|
| 11<br>EIM    | EIM<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled     |
| 10<br>CRC    | CRC<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled     |
| 9<br>AOI0    | AOI0<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled    |
| 8<br>DMA     | DMA<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled     |
| 7<br>WWDT0   | WWDT0<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled   |
| 6<br>UTICK0  | UTICK0<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled  |
| 5<br>FREQME  | FREQME<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled  |
| 4<br>CTIMER2 | CTIMER2<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled |
| 3<br>CTIMER1 | CTIMER1<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled |
| 2<br>CTIMER0 | CTIMER0<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled |
| 1<br>I3C0    | I3C0                                                                                         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                       |
|----------------|------------------------------------------------------------------------------------------------|
|                | 0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled              |
| 0<br>INPUTMUX0 | INPUTMUX0<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled |

#### 14.5.2.11 Control Automatic Clock Gating 1 (MRCC\_GLB\_ACC1)

##### Offset

| Register      | Offset |
|---------------|--------|
| MRCC_GLB_ACC1 | 84h    |

##### Diagram



##### Fields

| Field      | Function                                                                                   |
|------------|--------------------------------------------------------------------------------------------|
| 31-10<br>— | reserved<br>reserved                                                                       |
| 9<br>ROMCP | ROMCP<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled |
| 8<br>GPIO3 | GPIO3<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                   |
|------------|--------------------------------------------------------------------------------------------|
| 7<br>GPIO2 | GPIO2<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled |
| 6<br>GPIO1 | GPIO1<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled |
| 5<br>GPIO0 | GPIO0<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled |
| 4<br>RAMA  | RAMA<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled  |
| 3-1<br>—   | reserved<br>reserved                                                                       |
| 0<br>PORT3 | PORT3<br>0b - Automatic clock gating is disabled<br>1b - Automatic clock gating is enabled |

#### 14.5.2.12 I3C0\_FCLK clock selection control (MRCC\_I3C0\_FCLK\_CLKSEL)

##### Offset

| Register              | Offset |
|-----------------------|--------|
| MRCC_I3C0_FCLK_CLKSEL | A0h    |

**Diagram****Fields**

| Field      | Function                                                                                                                                                                                                                                                                                                                                         |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3       | reserved                                                                                                                                                                                                                                                                                                                                         |
| —          | reserved                                                                                                                                                                                                                                                                                                                                         |
| 2-0<br>MUX | <p>Functional Clock Mux Select</p> <p>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.</p> <ul style="list-style-type: none"> <li>000b - FRO_12M</li> <li>010b - FRO_HF_DIV</li> <li>011b - CLK_IN</li> <li>101b - CLK_1M</li> <li>111b - Reserved(NO Clock)</li> </ul> |

**14.5.2.13 I3C0\_FCLK clock divider control (MRCC\_I3C0\_FCLK\_CLKDIV)****Offset**

| Register              | Offset |
|-----------------------|--------|
| MRCC_I3C0_FCLK_CLKDIV | A4h    |

**Diagram**

| Bits  | 31         | 30   | 29        | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 |
|-------|------------|------|-----------|----|----|----|----|----|----|----|----|----|----|----|-----|----|
| R     | UNST<br>AB | HALT |           |    |    |    |    |    |    |    |    |    |    |    |     |    |
| W     |            |      | RESE<br>T |    |    |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 1    | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |
| Bits  | 15         | 14   | 13        | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0  |
| R     |            |      |           |    |    |    |    |    |    |    |    |    |    |    | DIV |    |
| W     |            |      |           |    |    |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 0    | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |

**Fields**

| Field        | Function                                                                                                                                                                          |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br><br>Determines the stability of the divider clock.<br><br>0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                |
| 30<br>HALT   | Halt divider counter<br><br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET  | Reset divider counter<br><br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—    | reserved<br><br>reserved                                                                                                                                                          |
| 3-0<br>DIV   | Functional Clock Divider<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

**14.5.2.14 CTIMER0 clock selection control (MRCC\_CTIMER0\_CLKSEL)****Offset**

| Register            | Offset |
|---------------------|--------|
| MRCC_CTIMER0_CLKSEL | A8h    |

**Diagram****Fields**

| Field | Function                                                                                                                                                                                                                                                |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3  | reserved                                                                                                                                                                                                                                                |
| —     | reserved                                                                                                                                                                                                                                                |
| 2-0   | Functional Clock Mux Select                                                                                                                                                                                                                             |
| MUX   | Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.<br><br>000b - FRO_12M<br>001b - FRO_HF_GATED<br>011b - CLK_IN<br>100b - CLK_16K<br>101b - CLK_1M<br>111b - Reserved(NO Clock) |

**14.5.2.15 CTIMER0 clock divider control (MRCC\_CTIMER0\_CLKDIV)****Offset**

| Register          | Offset |
|-------------------|--------|
| MRCC_CTIMER0_CLKD | ACh    |
| IV                |        |

**Diagram**

| Bits  | 31         | 30   | 29        | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 |
|-------|------------|------|-----------|----|----|----|----|----|----|----|----|----|----|----|-----|----|
| R     | UNST<br>AB | HALT |           |    |    |    |    |    |    |    |    |    |    |    |     |    |
| W     |            |      | RESE<br>T |    |    |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 1    | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |
| Bits  | 15         | 14   | 13        | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0  |
| R     |            |      |           |    |    |    |    |    |    |    |    |    |    |    | DIV |    |
| W     |            |      |           |    |    |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 0    | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |

**Fields**

| Field        | Function                                                                                                                                                                          |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br><br>Determines the stability of the divider clock.<br><br>0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                |
| 30<br>HALT   | Halt divider counter<br><br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET  | Reset divider counter<br><br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—    | reserved<br><br>reserved                                                                                                                                                          |
| 3-0<br>DIV   | Functional Clock Divider<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

**14.5.2.16 CTIMER1 clock selection control (MRCC\_CTIMER1\_CLKSEL)****Offset**

| Register            | Offset |
|---------------------|--------|
| MRCC_CTIMER1_CLKSEL | B0h    |

**Diagram****Fields**

| Field | Function                                                                                                                                                                                                                                                |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3  | reserved                                                                                                                                                                                                                                                |
| —     | reserved                                                                                                                                                                                                                                                |
| 2-0   | Functional Clock Mux Select                                                                                                                                                                                                                             |
| MUX   | Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.<br><br>000b - FRO_12M<br>001b - FRO_HF_GATED<br>011b - CLK_IN<br>100b - CLK_16K<br>101b - CLK_1M<br>111b - Reserved(NO Clock) |

**14.5.2.17 CTIMER1 clock divider control (MRCC\_CTIMER1\_CLKDIV)****Offset**

| Register          | Offset |
|-------------------|--------|
| MRCC_CTIMER1_CLKD | B4h    |
| IV                |        |

**Diagram**

| Bits  | 31         | 30   | 29        | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 |
|-------|------------|------|-----------|----|----|----|----|----|----|----|----|----|----|----|-----|----|
| R     | UNST<br>AB | HALT |           |    |    |    |    |    |    |    |    |    |    |    |     |    |
| W     |            |      | RESE<br>T |    |    |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 1    | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |
| Bits  | 15         | 14   | 13        | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0  |
| R     |            |      |           |    |    |    |    |    |    |    |    |    |    |    | DIV |    |
| W     |            |      |           |    |    |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 0    | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |

**Fields**

| Field        | Function                                                                                                                                                                          |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br><br>Determines the stability of the divider clock.<br><br>0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                |
| 30<br>HALT   | Halt divider counter<br><br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET  | Reset divider counter<br><br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—    | reserved<br><br>reserved                                                                                                                                                          |
| 3-0<br>DIV   | Functional Clock Divider<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

**14.5.2.18 CTIMER2 clock selection control (MRCC\_CTIMER2\_CLKSEL)****Offset**

| Register            | Offset |
|---------------------|--------|
| MRCC_CTIMER2_CLKSEL | B8h    |

**Diagram****Fields**

| Field | Function                                                                                                                                                                                                                                                |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3  | reserved                                                                                                                                                                                                                                                |
| —     | reserved                                                                                                                                                                                                                                                |
| 2-0   | Functional Clock Mux Select                                                                                                                                                                                                                             |
| MUX   | Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.<br><br>000b - FRO_12M<br>001b - FRO_HF_GATED<br>011b - CLK_IN<br>100b - CLK_16K<br>101b - CLK_1M<br>111b - Reserved(NO Clock) |

**14.5.2.19 CTIMER2 clock divider control (MRCC\_CTIMER2\_CLKDIV)****Offset**

| Register          | Offset |
|-------------------|--------|
| MRCC_CTIMER2_CLKD | BCh    |
| IV                |        |

**Diagram**

| Bits  | 31         | 30   | 29        | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 |
|-------|------------|------|-----------|----|----|----|----|----|----|----|----|----|----|----|-----|----|
| R     | UNST<br>AB | HALT |           |    |    |    |    |    |    |    |    |    |    |    |     |    |
| W     |            |      | RESE<br>T |    |    |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 1    | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |
| Bits  | 15         | 14   | 13        | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0  |
| R     |            |      |           |    |    |    |    |    |    |    |    |    |    |    | DIV |    |
| W     |            |      |           |    |    |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 0    | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |

**Fields**

| Field        | Function                                                                                                                                                                          |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br><br>Determines the stability of the divider clock.<br><br>0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                |
| 30<br>HALT   | Halt divider counter<br><br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET  | Reset divider counter<br><br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—    | reserved<br><br>reserved                                                                                                                                                          |
| 3-0<br>DIV   | Functional Clock Divider<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

**14.5.2.20 WWDT0 clock divider control (MRCC\_WWDT0\_CLKDIV)****Offset**

| Register          | Offset |
|-------------------|--------|
| MRCC_WWDT0_CLKDIV | C4h    |

**Diagram**

| Bits  | 31         | 30 | 29   | 28 | 27        | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 |
|-------|------------|----|------|----|-----------|----|----|----|----|----|----|----|----|----|-----|----|
| R     | UNST<br>AB |    | HALT |    | RESE<br>T |    |    |    |    |    |    |    |    |    |     |    |
| W     |            |    |      |    |           |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 0  | 0    | 0  | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |
| Bits  | 15         | 14 | 13   | 12 | 11        | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0  |
| R     |            |    |      |    |           |    |    |    |    |    |    |    |    |    | DIV |    |
| W     |            |    |      |    |           |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 0  | 0    | 0  | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |

**Fields**

| Field        | Function                                                                                                                                                                          |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br><br>Determines the stability of the divider clock.<br><br>0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                |
| 30<br>HALT   | Halt divider counter<br><br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET  | Reset divider counter<br><br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—    | reserved<br><br>reserved                                                                                                                                                          |
| 3-0<br>DIV   | Functional Clock Divider<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

**14.5.2.21 LPI2C0 clock selection control (MRCC\_LPI2C0\_CLKSEL)****Offset**

| Register           | Offset |
|--------------------|--------|
| MRCC_LPI2C0_CLKSEL | C8h    |

**Diagram****Fields**

| Field | Function                                                                                                                                                                                                                            |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3  | reserved                                                                                                                                                                                                                            |
| —     | reserved                                                                                                                                                                                                                            |
| 2-0   | Functional Clock Mux Select                                                                                                                                                                                                         |
| MUX   | Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.<br><br>000b - FRO_12M<br>010b - FRO_HF_DIV<br>011b - CLK_IN<br>101b - CLK_1M<br>111b - Reserved(NO Clock) |

**14.5.2.22 LPI2C0 clock divider control (MRCC\_LPI2C0\_CLKDIV)****Offset**

| Register           | Offset |
|--------------------|--------|
| MRCC_LPI2C0_CLKDIV | CCh    |

**Diagram**

| Bits  | 31         | 30   | 29        | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 |
|-------|------------|------|-----------|----|----|----|----|----|----|----|----|----|----|----|-----|----|
| R     | UNST<br>AB | HALT |           |    |    |    |    |    |    |    |    |    |    |    |     |    |
| W     |            |      | RESE<br>T |    |    |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 1    | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |
| Bits  | 15         | 14   | 13        | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0  |
| R     |            |      |           |    |    |    |    |    |    |    |    |    |    |    | DIV |    |
| W     |            |      |           |    |    |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 0    | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |

**Fields**

| Field        | Function                                                                                                                                                                          |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br><br>Determines the stability of the divider clock.<br><br>0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                |
| 30<br>HALT   | Halt divider counter<br><br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET  | Reset divider counter<br><br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—    | reserved<br><br>reserved                                                                                                                                                          |
| 3-0<br>DIV   | Functional Clock Divider<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

**14.5.2.23 LPSPI0 clock selection control (MRCC\_LPSPI0\_CLKSEL)****Offset**

| Register           | Offset |
|--------------------|--------|
| MRCC_LPSPI0_CLKSEL | D0h    |

**Diagram****Fields**

| Field | Function                                                                                                                                                                                                                            |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3  | reserved                                                                                                                                                                                                                            |
| —     | reserved                                                                                                                                                                                                                            |
| 2-0   | Functional Clock Mux Select                                                                                                                                                                                                         |
| MUX   | Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.<br><br>000b - FRO_12M<br>010b - FRO_HF_DIV<br>011b - CLK_IN<br>101b - CLK_1M<br>111b - Reserved(NO Clock) |

**14.5.2.24 LPSPI0 clock divider control (MRCC\_LPSPI0\_CLKDIV)****Offset**

| Register           | Offset |
|--------------------|--------|
| MRCC_LPSPI0_CLKDIV | D4h    |

**Diagram**

| Bits  | 31         | 30   | 29        | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 |
|-------|------------|------|-----------|----|----|----|----|----|----|----|----|----|----|----|-----|----|
| R     | UNST<br>AB | HALT |           |    |    |    |    |    |    |    |    |    |    |    |     |    |
| W     |            |      | RESE<br>T |    |    |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 1    | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |
| Bits  | 15         | 14   | 13        | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0  |
| R     |            |      |           |    |    |    |    |    |    |    |    |    |    |    | DIV |    |
| W     |            |      |           |    |    |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 0    | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |

**Fields**

| Field        | Function                                                                                                                                                                          |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br><br>Determines the stability of the divider clock.<br><br>0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                |
| 30<br>HALT   | Halt divider counter<br><br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET  | Reset divider counter<br><br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—    | reserved<br><br>reserved                                                                                                                                                          |
| 3-0<br>DIV   | Functional Clock Divider<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

**14.5.2.25 LPSPI1 clock selection control (MRCC\_LPSPI1\_CLKSEL)****Offset**

| Register           | Offset |
|--------------------|--------|
| MRCC_LPSPI1_CLKSEL | D8h    |

**Diagram****Fields**

| Field | Function                                                                                                                                                                                                                                                           |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3  | reserved                                                                                                                                                                                                                                                           |
| —     | reserved                                                                                                                                                                                                                                                           |
| 2-0   | Functional Clock Mux Select                                                                                                                                                                                                                                        |
| MUX   | <p>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.</p> <p>000b - FRO_12M<br/>     010b - FRO_HF_DIV<br/>     011b - CLK_IN<br/>     101b - CLK_1M<br/>     111b - Reserved(NO Clock)</p> |

**14.5.2.26 LPSPI1 clock divider control (MRCC\_LPSP1\_CLKDIV)****Offset**

| Register          | Offset |
|-------------------|--------|
| MRCC_LPSP1_CLKDIV | DCh    |

**Diagram**

| Bits  | 31         | 30 | 29   | 28 | 27        | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 |
|-------|------------|----|------|----|-----------|----|----|----|----|----|----|----|----|----|-----|----|
| R     | UNST<br>AB |    | HALT |    | RESE<br>T |    |    |    |    |    |    |    |    |    |     |    |
| W     |            |    |      |    |           |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 1  | 0    | 0  | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |
| Bits  | 15         | 14 | 13   | 12 | 11        | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0  |
| R     |            |    |      |    |           |    |    |    |    |    |    |    |    |    | DIV |    |
| W     |            |    |      |    |           |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 0  | 0    | 0  | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |

**Fields**

| Field        | Function                                                                                                                                                                          |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br><br>Determines the stability of the divider clock.<br><br>0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                |
| 30<br>HALT   | Halt divider counter<br><br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET  | Reset divider counter<br><br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—    | reserved<br><br>reserved                                                                                                                                                          |
| 3-0<br>DIV   | Functional Clock Divider<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

**14.5.2.27 LPUART0 clock selection control (MRCC\_LPUART0\_CLKSEL)****Offset**

| Register            | Offset |
|---------------------|--------|
| MRCC_LPUART0_CLKSEL | E0h    |

**Diagram****Fields**

| Field | Function                                                                                                                                                                                                                                              |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3  | reserved                                                                                                                                                                                                                                              |
| —     | reserved                                                                                                                                                                                                                                              |
| 2-0   | Functional Clock Mux Select                                                                                                                                                                                                                           |
| MUX   | Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.<br><br>000b - FRO_12M<br>010b - FRO_HF_DIV<br>011b - CLK_IN<br>100b - CLK_16K<br>101b - CLK_1M<br>111b - Reserved(NO Clock) |

**14.5.2.28 LPUART0 clock divider control (MRCC\_LPUART0\_CLKDIV)****Offset**

| Register          | Offset |
|-------------------|--------|
| MRCC_LPUART0_CLKD | E4h    |
| IV                |        |

**Diagram**

| Bits  | 31         | 30 | 29   | 28 | 27        | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 |
|-------|------------|----|------|----|-----------|----|----|----|----|----|----|----|----|----|-----|----|
| R     | UNST<br>AB |    | HALT |    | RESE<br>T |    |    |    |    |    |    |    |    |    |     |    |
| W     |            |    |      |    |           |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 1  | 0    | 0  | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |
| Bits  | 15         | 14 | 13   | 12 | 11        | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0  |
| R     |            |    |      |    |           |    |    |    |    |    |    |    |    |    | DIV |    |
| W     |            |    |      |    |           |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 0  | 0    | 0  | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |

**Fields**

| Field        | Function                                                                                                                                                                          |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br><br>Determines the stability of the divider clock.<br><br>0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                |
| 30<br>HALT   | Halt divider counter<br><br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET  | Reset divider counter<br><br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—    | reserved<br><br>reserved                                                                                                                                                          |
| 3-0<br>DIV   | Functional Clock Divider<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

**14.5.2.29 LPUART1 clock selection control (MRCC\_LPUART1\_CLKSEL)****Offset**

| Register            | Offset |
|---------------------|--------|
| MRCC_LPUART1_CLKSEL | E8h    |

**Diagram****Fields**

| Field | Function                                                                                                                                                                                                                                              |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3  | reserved                                                                                                                                                                                                                                              |
| —     | reserved                                                                                                                                                                                                                                              |
| 2-0   | Functional Clock Mux Select                                                                                                                                                                                                                           |
| MUX   | Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.<br><br>000b - FRO_12M<br>010b - FRO_HF_DIV<br>011b - CLK_IN<br>100b - CLK_16K<br>101b - CLK_1M<br>111b - Reserved(NO Clock) |

**14.5.2.30 LPUART1 clock divider control (MRCC\_LPUART1\_CLKDIV)****Offset**

| Register          | Offset |
|-------------------|--------|
| MRCC_LPUART1_CLKD | ECh    |
| IV                |        |

**Diagram**

| Bits  | 31         | 30 | 29   | 28 | 27        | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 |
|-------|------------|----|------|----|-----------|----|----|----|----|----|----|----|----|----|-----|----|
| R     | UNST<br>AB |    | HALT |    | RESE<br>T |    |    |    |    |    |    |    |    |    |     |    |
| W     |            |    |      |    |           |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 1  | 0    | 0  | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |
| Bits  | 15         | 14 | 13   | 12 | 11        | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0  |
| R     |            |    |      |    |           |    |    |    |    |    |    |    |    |    | DIV |    |
| W     |            |    |      |    |           |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 0  | 0    | 0  | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |

**Fields**

| Field        | Function                                                                                                                                                                          |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br><br>Determines the stability of the divider clock.<br><br>0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                |
| 30<br>HALT   | Halt divider counter<br><br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET  | Reset divider counter<br><br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—    | reserved<br><br>reserved                                                                                                                                                          |
| 3-0<br>DIV   | Functional Clock Divider<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

**14.5.2.31 LPUART2 clock selection control (MRCC\_LPUART2\_CLKSEL)****Offset**

| Register            | Offset |
|---------------------|--------|
| MRCC_LPUART2_CLKSEL | F0h    |

**Diagram****Fields**

| Field | Function                                                                                                                                                                                                                                              |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3  | reserved                                                                                                                                                                                                                                              |
| —     | reserved                                                                                                                                                                                                                                              |
| 2-0   | Functional Clock Mux Select                                                                                                                                                                                                                           |
| MUX   | Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.<br><br>000b - FRO_12M<br>010b - FRO_HF_DIV<br>011b - CLK_IN<br>100b - CLK_16K<br>101b - CLK_1M<br>111b - Reserved(NO Clock) |

**14.5.2.32 LPUART2 clock divider control (MRCC\_LPUART2\_CLKDIV)****Offset**

| Register          | Offset |
|-------------------|--------|
| MRCC_LPUART2_CLKD | F4h    |
| IV                |        |

**Diagram**

| Bits  | 31         | 30 | 29   | 28 | 27        | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 |
|-------|------------|----|------|----|-----------|----|----|----|----|----|----|----|----|----|-----|----|
| R     | UNST<br>AB |    | HALT |    | RESE<br>T |    |    |    |    |    |    |    |    |    |     |    |
| W     |            |    |      |    |           |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 1  | 0    | 0  | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |
| Bits  | 15         | 14 | 13   | 12 | 11        | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0  |
| R     |            |    |      |    |           |    |    |    |    |    |    |    |    |    | DIV |    |
| W     |            |    |      |    |           |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 0  | 0    | 0  | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |

**Fields**

| Field        | Function                                                                                                                                                                          |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br><br>Determines the stability of the divider clock.<br><br>0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                |
| 30<br>HALT   | Halt divider counter<br><br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET  | Reset divider counter<br><br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—    | reserved<br><br>reserved                                                                                                                                                          |
| 3-0<br>DIV   | Functional Clock Divider<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

**14.5.2.33 USB0 clock selection control (MRCC\_USB0\_CLKSEL)****Offset**

| Register         | Offset |
|------------------|--------|
| MRCC_USB0_CLKSEL | F8h    |

**Diagram****Fields**

| Field      | Function                                                                                                                                                                                                                                                                                    |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2       | reserved                                                                                                                                                                                                                                                                                    |
| —          | reserved                                                                                                                                                                                                                                                                                    |
| 1-0<br>MUX | <p>Functional Clock Mux Select</p> <p>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.</p> <ul style="list-style-type: none"> <li>01b - CLK_48M</li> <li>10b - CLK_IN</li> <li>11b - Reserved(NO Clock)</li> </ul> |

**14.5.2.34 LPTMR0 clock selection control (MRCC\_LPTMR0\_CLKSEL)****Offset**

| Register           | Offset |
|--------------------|--------|
| MRCC_LPTMR0_CLKSEL | 100h   |

**Diagram****Fields**

| Field | Function                                                                                                                                                                                                                            |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3  | reserved                                                                                                                                                                                                                            |
| —     | reserved                                                                                                                                                                                                                            |
| 2-0   | Functional Clock Mux Select                                                                                                                                                                                                         |
| MUX   | Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.<br><br>000b - FRO_12M<br>010b - FRO_HF_DIV<br>011b - CLK_IN<br>101b - CLK_1M<br>111b - Reserved(NO Clock) |

**14.5.2.35 LPTMR0 clock divider control (MRCC\_LPTMR0\_CLKDIV)****Offset**

| Register          | Offset |
|-------------------|--------|
| MRCC_LPTMR0_CLKDI | 104h   |

**Diagram**

| Bits  | 31         | 30   | 29        | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16 |
|-------|------------|------|-----------|----|----|----|----|----|----|----|----|----|----|----|-----|----|
| R     | UNST<br>AB | HALT |           |    |    |    |    |    |    |    |    |    |    |    |     |    |
| W     |            |      | RESE<br>T |    |    |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 1    | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |
| Bits  | 15         | 14   | 13        | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0  |
| R     |            |      |           |    |    |    |    |    |    |    |    |    |    |    | DIV |    |
| W     |            |      |           |    |    |    |    |    |    |    |    |    |    |    |     |    |
| Reset | 0          | 0    | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0  |

**Fields**

| Field        | Function                                                                                                                                                                          |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br><br>Determines the stability of the divider clock.<br><br>0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                |
| 30<br>HALT   | Halt divider counter<br><br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET  | Reset divider counter<br><br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—    | reserved<br><br>reserved                                                                                                                                                          |
| 3-0<br>DIV   | Functional Clock Divider<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

**14.5.2.36 OSTIMER0 clock selection control (MRCC\_OSTIMER0\_CLKSEL)****Offset**

| Register             | Offset |
|----------------------|--------|
| MRCC_OSTIMER0_CLKSEL | 108h   |

**Diagram****Fields**

| Field      | Function                                                                                                                                                                                                                                                                                     |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2       | reserved                                                                                                                                                                                                                                                                                     |
| —          | reserved                                                                                                                                                                                                                                                                                     |
| 1-0<br>MUX | <p>Functional Clock Mux Select</p> <p>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.</p> <ul style="list-style-type: none"> <li>00b - CLK_16K</li> <li>10b - CLK_1M</li> <li>11b - Reserved2(NO Clock)</li> </ul> |

**14.5.2.37 ADC0 clock selection control (MRCC\_ADC0\_CLKSEL)****Offset**

| Register         | Offset |
|------------------|--------|
| MRCC_ADC0_CLKSEL | 110h   |

**Diagram**

**Fields**

| Field      | Function                                                                                                                                                                                                                                                                 |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3<br>—  | reserved<br>reserved                                                                                                                                                                                                                                                     |
| 2-0<br>MUX | Functional Clock Mux Select<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.<br><br>000b - FRO_12M<br>001b - FRO_HF_GATED<br>011b - CLK_IN<br>101b - CLK_1M<br>111b - Reserved(NO Clock) |

**14.5.2.38 ADC0 clock divider control (MRCC\_ADC0\_CLKDIV)****Offset**

| Register         | Offset |
|------------------|--------|
| MRCC_ADC0_CLKDIV | 114h   |

**Diagram****Fields**

| Field  | Function                                       |
|--------|------------------------------------------------|
| 31     | Divider status flag                            |
| UNSTAB | Determines the stability of the divider clock. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                      |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                                                                                             |
| 30<br>HALT  | Halt divider counter<br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET | Reset divider counter<br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—   | reserved<br>reserved                                                                                                                                                          |
| 3-0<br>DIV  | Functional Clock Divider<br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

#### 14.5.2.39 CMP0\_FUNC clock divider control (MRCC\_CMP0\_FUNC\_CLKDIV)

##### Offset

| Register                  | Offset |
|---------------------------|--------|
| MRCC_CMP0_FUNC_C<br>LKDIV | 11Ch   |

##### Diagram



**Fields**

| Field        | Function                                                                                                                                                                      |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br>Determines the stability of the divider clock.<br>0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                    |
| 30<br>HALT   | Halt divider counter<br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET  | Reset divider counter<br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—    | reserved<br>reserved                                                                                                                                                          |
| 3-0<br>DIV   | Functional Clock Divider<br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

**14.5.2.40 CMP0\_RR clock selection control (MRCC\_CMP0\_RR\_CLKSEL)****Offset**

| Register            | Offset |
|---------------------|--------|
| MRCC_CMP0_RR_CLKSEL | 120h   |

**Diagram**

**Fields**

| Field      | Function                                                                                                                                                                                                                                                               |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3<br>—  | reserved<br>reserved                                                                                                                                                                                                                                                   |
| 2-0<br>MUX | Functional Clock Mux Select<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.<br><br>000b - FRO_12M<br>010b - FRO_HF_DIV<br>011b - CLK_IN<br>101b - CLK_1M<br>111b - Reserved(NO Clock) |

**14.5.2.41 CMP0\_RR clock divider control (MRCC\_CMP0\_RR\_CLKDIV)****Offset**

| Register            | Offset |
|---------------------|--------|
| MRCC_CMP0_RR_CLKDIV | 124h   |

**Diagram****Fields**

| Field        | Function                                                                  |
|--------------|---------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br><br>Determines the stability of the divider clock. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                      |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                                                                                             |
| 30<br>HALT  | Halt divider counter<br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET | Reset divider counter<br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—   | reserved<br>reserved                                                                                                                                                          |
| 3-2<br>—    | Reserved                                                                                                                                                                      |
| 1-0<br>DIV  | Functional Clock Divider<br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

#### 14.5.2.42 CMP1\_FUNC clock divider control (MRCC\_CMP1\_FUNC\_CLKDIV)

##### Offset

| Register                  | Offset |
|---------------------------|--------|
| MRCC_CMP1_FUNC_C<br>LKDIV | 12Ch   |

##### Diagram



**Fields**

| Field        | Function                                                                                                                                                                      |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br>Determines the stability of the divider clock.<br>0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                    |
| 30<br>HALT   | Halt divider counter<br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET  | Reset divider counter<br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—    | reserved<br>reserved                                                                                                                                                          |
| 3-0<br>DIV   | Functional Clock Divider<br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

**14.5.2.43 CMP1\_RR clock selection control (MRCC\_CMP1\_RR\_CLKSEL)****Offset**

| Register             | Offset |
|----------------------|--------|
| MRCC_CMP1_RR_CLK_SEL | 130h   |

**Diagram**

**Fields**

| Field      | Function                                                                                                                                                                                                                                                               |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3<br>—  | reserved<br>reserved                                                                                                                                                                                                                                                   |
| 2-0<br>MUX | Functional Clock Mux Select<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.<br><br>000b - FRO_12M<br>010b - FRO_HF_DIV<br>011b - CLK_IN<br>101b - CLK_1M<br>111b - Reserved(NO Clock) |

**14.5.2.44 CMP1\_RR clock divider control (MRCC\_CMP1\_RR\_CLKDIV)****Offset**

| Register            | Offset |
|---------------------|--------|
| MRCC_CMP1_RR_CLKDIV | 134h   |

**Diagram****Fields**

| Field        | Function                                                                  |
|--------------|---------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br><br>Determines the stability of the divider clock. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                      |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                                                                                             |
| 30<br>HALT  | Halt divider counter<br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET | Reset divider counter<br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—   | reserved<br>reserved                                                                                                                                                          |
| 3-2<br>—    | Reserved                                                                                                                                                                      |
| 1-0<br>DIV  | Functional Clock Divider<br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

#### 14.5.2.45 DBG\_TRACE clock selection control (MRCC\_DBG\_TRACE\_CLKSEL)

##### Offset

| Register                  | Offset |
|---------------------------|--------|
| MRCC_DBG_TRACE_C<br>LKSEL | 138h   |

##### Diagram



**Fields**

| Field      | Function                                                                                                                                                                                                                                        |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2<br>—  | reserved<br>reserved                                                                                                                                                                                                                            |
| 1-0<br>MUX | Functional Clock Mux Select<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.<br><br>00b - CPU_CLK<br>01b - CLK_1M<br>10b - CLK_16K<br>11b - Reserved2(NO Clock) |

**14.5.2.46 DBG\_TRACE clock divider control (MRCC\_DBG\_TRACE\_CLKDIV)****Offset**

| Register                  | Offset |
|---------------------------|--------|
| MRCC_DBG_TRACE_C<br>LKDIV | 13Ch   |

**Diagram****Fields**

| Field        | Function                                                                  |
|--------------|---------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br><br>Determines the stability of the divider clock. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                      |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                                                                                             |
| 30<br>HALT  | Halt divider counter<br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET | Reset divider counter<br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—   | reserved<br>reserved                                                                                                                                                          |
| 3-0<br>DIV  | Functional Clock Divider<br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

#### 14.5.2.47 CLKOUT clock selection control (MRCC\_CLKOUT\_CLKSEL)

##### Offset

| Register           | Offset |
|--------------------|--------|
| MRCC_CLKOUT_CLKSEL | 140h   |

##### Diagram



**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                   |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3<br>—  | reserved<br>reserved                                                                                                                                                                                                                                                                       |
| 2-0<br>MUX | Functional Clock Mux Select<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.<br><br>000b - FRO_12M<br>001b - FRO_HF_DIV<br>010b - CLK_IN<br>011b - CLK_16K<br>110b - SLOW_CLK<br>111b - Reserved(NO Clock) |

**14.5.2.48 CLKOUT clock divider control (MRCC\_CLKOUT\_CLKDIV)****Offset**

| Register               | Offset |
|------------------------|--------|
| MRCC_CLKOUT_CLKDI<br>V | 144h   |

**Diagram****Fields**

| Field | Function            |
|-------|---------------------|
| 31    | Divider status flag |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                      |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| UNSTAB      | Determines the stability of the divider clock.<br>0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                                           |
| 30<br>HALT  | Halt divider counter<br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET | Reset divider counter<br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—   | reserved<br>reserved                                                                                                                                                          |
| 3-0<br>DIV  | Functional Clock Divider<br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

#### 14.5.2.49 SYSTICK clock selection control (MRCC\_SYSTICK\_CLKSEL)

##### Offset

| Register            | Offset |
|---------------------|--------|
| MRCC_SYSTICK_CLKSEL | 148h   |

##### Diagram



**Fields**

| Field      | Function                                                                                                                                                                                                                                        |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2<br>—  | reserved<br>reserved                                                                                                                                                                                                                            |
| 1-0<br>MUX | Functional Clock Mux Select<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0.<br><br>00b - CPU_CLK<br>01b - CLK_1M<br>10b - CLK_16K<br>11b - Reserved2(NO Clock) |

**14.5.2.50 SYSTICK clock divider control (MRCC\_SYSTICK\_CLKDIV)****Offset**

| Register                | Offset |
|-------------------------|--------|
| MRCC_SYSTICK_CLKDI<br>V | 14Ch   |

**Diagram****Fields**

| Field        | Function                                                                  |
|--------------|---------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br><br>Determines the stability of the divider clock. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                      |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                                                                                             |
| 30<br>HALT  | Halt divider counter<br>0b - Divider clock is running<br>1b - Divider clock is stopped                                                                                        |
| 29<br>RESET | Reset divider counter<br>0b - Divider isn't reset<br>1b - Divider is reset                                                                                                    |
| 28-4<br>—   | reserved<br>reserved                                                                                                                                                          |
| 3-0<br>DIV  | Functional Clock Divider<br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

#### 14.5.2.51 FRO\_HF\_DIV clock divider control (MRCC\_FRO\_HF\_DIV\_CLKDIV)

##### Offset

| Register                   | Offset |
|----------------------------|--------|
| MRCC_FRO_HF_DIV_C<br>LKDIV | 154h   |

##### Diagram



**Fields**

| Field        | Function                                                                                                                                                                          |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>UNSTAB | Divider status flag<br><br>Determines the stability of the divider clock.<br><br>0b - Divider clock is stable<br>1b - Clock frequency isn't stable                                |
| 30-4<br>—    | reserved<br>reserved                                                                                                                                                              |
| 3-0<br>DIV   | Functional Clock Divider<br><br>Before change peripheral's functional clock source, should configure the module's MRCC_GLB_CC and MRCC_GLB_ACC bits to 0. divider value = (DIV+1) |

**14.5.3 GLIKEY register descriptions****14.5.3.1 GLIKEY memory map**

GLIKEY0 base address: 4009\_1D00h

| Offset | Register                        | Width<br>(In bits) | Access | Reset value                 |
|--------|---------------------------------|--------------------|--------|-----------------------------|
| 0h     | Control Register 0 SFR (CTRL_0) | 32                 | RW     | <a href="#">See section</a> |
| 4h     | Control Register 1 SFR (CTRL_1) | 32                 | RW     | <a href="#">See section</a> |
| 8h     | Interrupt Control (INTR_CTRL)   | 32                 | RW     | <a href="#">See section</a> |
| Ch     | Status (STATUS)                 | 32                 | R      | <a href="#">See section</a> |
| FCh    | IP Version (VERSION)            | 32                 | R      | 007B_0100h                  |

**14.5.3.2 Control Register 0 SFR (CTRL\_0)****Offset**

| Register | Offset |
|----------|--------|
| CTRL_0   | 0h     |

**Function**

Control Register 0 SFR controls the flow of FSM

**Diagram**

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

**Fields**

| Field               | Function                                                                                                                                                                                                 |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-19<br>RESERVED31 | Reserved for Future Use                                                                                                                                                                                  |
| 18<br>SFT_RST       | Soft reset for the core reset (SFR configuration will be preserved). This register reads as 0<br>Use this field to bring the logic into a known state.<br>0b - No effect<br>1b - Triggers the soft reset |
| 17-16<br>WR_EN_0    | Write Enable 0<br>Controls the state of FSM. Use these bits with Write Enable 1.                                                                                                                         |
| 15-8<br>RESERVED15  | Reserved for Future Use                                                                                                                                                                                  |
| 7-0<br>WRITE_INDEX  | Write Index<br>Targets given index for SSR.                                                                                                                                                              |

**14.5.3.3 Control Register 1 SFR (CTRL\_1)****Offset**

| Register | Offset |
|----------|--------|
| CTRL_1   | 4h     |

**Function**

Control Register 1 SFR controls the flow of FSM.

**Diagram**

| Bits  | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23         | 22 | 21 | 20 | 19      | 18 | 17 | 16 |
|-------|------------|----|----|----|----|----|----|----|------------|----|----|----|---------|----|----|----|
| R     | RESERVED31 |    |    |    |    |    |    |    | SFR_LOCK   |    |    |    | WR_EN_1 |    |    |    |
| W     |            |    |    |    |    |    |    |    |            |    |    |    |         |    |    |    |
| Reset | u          | u  | u  | u  | u  | u  | u  | u  | u          | u  | 1  | 0  | 1       | 0  | 0  | 0  |
| Bits  | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7          | 6  | 5  | 4  | 3       | 2  | 1  | 0  |
| R     | RESERVED15 |    |    |    |    |    |    |    | READ_INDEX |    |    |    |         |    |    |    |
| W     |            |    |    |    |    |    |    |    |            |    |    |    |         |    |    |    |
| Reset | u          | u  | u  | u  | u  | u  | u  | u  | 0          | 0  | 0  | 0  | 0       | 0  | 0  | 0  |

**Fields**

| Field               | Function                                                                                                                                                                          |
|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-22<br>RESERVED31 | Reserved for Future Use                                                                                                                                                           |
| 21-18<br>SFR_LOCK   | LOCK register for GLIKEY<br>LOCK register for GLIKEY<br>4'h5 - Locked<br>4'hA - Unlocked<br><br><b>NOTE</b><br>When IP is locked, Write access to SFR is invalid                  |
| 17-16<br>WR_EN_1    | Write Enable One                                                                                                                                                                  |
| 15-8<br>RESERVED15  | Reserved for Future Use                                                                                                                                                           |
| 7-0<br>READ_INDEX   | Index status, Writing an index value to this register will request the block to return the lock status of this index.<br><br>Use this field to read the status of a target index. |

**14.5.3.4 Interrupt Control (INTR\_CTRL)****Offset**

| Register  | Offset |
|-----------|--------|
| INTR_CTRL | 8h     |

**Function**

Interrupt Control Register

**Diagram**

| Bits  | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19      | 18      | 17     | 16 |
|-------|------------|----|----|----|----|----|----|----|----|----|----|----|---------|---------|--------|----|
| Reset | u          | u  | u  | u  | u  | u  | u  | u  | u  | u  | u  | u  | u       | u       | u      | u  |
| Bits  | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3       | 2       | 1      | 0  |
| Reset | u          | u  | u  | u  | u  | u  | u  | u  | u  | u  | u  | u  | u       | 0       | 0      | 0  |
| R     | RESERVED31 |    |    |    |    |    |    |    |    |    |    |    | INT_SET | INT_CLR | INT_EN |    |
| W     |            |    |    |    |    |    |    |    |    |    |    |    | 0       | 0       | 0      |    |

**Fields**

| Field              | Function                                                                                                                                                                                                           |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3<br>RESERVED31 | Reserved for Future Use                                                                                                                                                                                            |
| 2<br>INT_SET       | Interrupt Set. Writing a 1 to this register asserts the interrupt. This register reads as 0<br>Use this field to set interrupt.<br>0b - No effect<br>1b - Triggers interrupt                                       |
| 1<br>INT_CLR       | Interrupt Clear. Writing a 1 to this register creates a single interrupt clear pulse. This register reads as 0<br>When the interrupt is set, use this field to clear this interrupt by writing 1 to this register. |
| 0<br>INT_EN        | Interrupt Enable. Writing a 1, Interrupt asserts on Interrupt output port<br>Use this field to control whether to trigger an interrupt.                                                                            |

**14.5.3.5 Status (STATUS)****Offset**

| Register | Offset |
|----------|--------|
| STATUS   | Ch     |

**Function**

Status Register provides the status of GLIKEY

**Diagram**

| Bits  | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17           | 16         |            |
|-------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|------------|------------|
| R     | FSM_STATE  |    |    |    |    |    |    |    |    |    |    |    |    |    | RESERVED18   |            |            |
| W     |            |    |    |    |    |    |    |    |    |    |    |    |    |    |              |            |            |
| Reset | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 1  | 0  | u  | u            | u          |            |
| Bits  | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1            | 0          |            |
| R     | RESERVED18 |    |    |    |    |    |    |    |    |    |    |    |    |    | ERROR_STATUS | LOCK_ST... | INT_STA... |
| W     |            |    |    |    |    |    |    |    |    |    |    |    |    |    |              |            |            |
| Reset | u          | u  | u  | u  | u  | u  | u  | u  | u  | u  | u  | 0  | 0  | 0  | 0            | 0          |            |

**Fields**

| Field               | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-19<br>FSM_STATE  | Status of FSM<br>Status of FSM<br>13'b0_0000_0000_1011: WR_DISABLED<br>13'b0_0000_0001_0110: INIT<br>13'b0_0000_0010_1100: STEP1<br>13'b0_0000_0101_1000: STEP2<br>13'b0_0000_1011_0000: STEP3<br>13'b0_0001_0110_0000: STEP4<br>13'b0_0010_1100_0000: STEP5<br>13'b0_0101_1000_0000: STEP6<br>13'b0_1011_0000_0000: STEP7<br>13'b1_0110_0000_0000: STEP8<br>13'b0_1100_0000_0001: LOCKED<br>13'b1_1000_0000_0010: WR_ENABLED<br>13'b1_0000_0000_0101: SSR_RESET |
| 18-5<br>RESERVED18  | Reserved for Future Use                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 4-2<br>ERROR_STATUS | Status of the Error<br>Reports the status of error in GLIKEY, where Bit 0 (1 at position 0) indicates that an FSM occurred.<br>Bit 1 (1 at position 1) indicates that software tried to address write index greater than the available value.<br>Bit 2 (1 at position 2) indicates that software tried to address read index greater than the available value.<br>000b - No error                                                                                |

Table continues on the next page...

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                                                        |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | 001b - FSM error has occurred<br>010b - Write index out of the bound (OOB) error<br>011b - Write index OOB and FSM error<br>100b - Read index OOB error<br>110b - Write index and read index OOB error<br>111b - Read index OOB, write index OOB, and FSM error |
| 1<br>LOCK_STATUS | Provides the current lock status of indexes.<br>0b - Current read index is not locked<br>1b - Current read index is locked                                                                                                                                      |
| 0<br>INT_STATUS  | Interrupt Status.<br>Reflects the current status of interrupt.<br>0b - No effect<br>1b - Triggers interrupt                                                                                                                                                     |

#### 14.5.3.6 IP Version (VERSION)

##### Offset

| Register | Offset |
|----------|--------|
| VERSION  | FCh    |

##### Function

IP Version register

##### Diagram

| Bits  | 31         | 30 | 29 | 28 | 27           | 26 | 25 | 24 | 23        | 22 | 21         | 20 | 19         | 18 | 17 | 16 |
|-------|------------|----|----|----|--------------|----|----|----|-----------|----|------------|----|------------|----|----|----|
| R     | Reserved31 |    |    |    | INDEX_CONFIG |    |    |    |           |    | FSM_CON... |    | Reserved16 |    |    |    |
| W     |            |    |    |    |              |    |    |    |           |    |            |    |            |    |    |    |
| Reset | 0          | 0  | 0  | 0  | 0            | 0  | 0  | 0  | 0         | 1  | 1          | 1  | 1          | 0  | 1  | 1  |
| Bits  | 15         | 14 | 13 | 12 | 11           | 10 | 9  | 8  | 7         | 6  | 5          | 4  | 3          | 2  | 1  | 0  |
| R     | Reserved15 |    |    |    | Reserved11   |    |    |    | Reserved7 |    |            |    | Reserved3  |    |    |    |
| W     |            |    |    |    |              |    |    |    |           |    |            |    |            |    |    |    |
| Reset | 0          | 0  | 0  | 0  | 0            | 0  | 0  | 1  | 0         | 0  | 0          | 0  | 0          | 0  | 0  | 0  |

**Fields**

| Field                 | Function                                 |
|-----------------------|------------------------------------------|
| 31-27<br>Reserved31   | Reserved for Future Use                  |
| 26-19<br>INDEX_CONFIG | Configured number of addressable indexes |
| 18<br>FSM_CONFIG      | 0:4 step, 1:8 step                       |
| 17-16<br>Reserved16   | Reserved                                 |
| 15-12<br>Reserved15   | Reserved                                 |
| 11-8<br>Reserved11    | Reserved                                 |
| 7-4<br>Reserved7      | Reserved                                 |
| 3-0<br>Reserved3      | Reserved                                 |

**14.6 Application information**

Peripheral clock is gated by using CC ( CC = {MRCC\_GLB\_ACC.[peripherals name], MRCC\_GLB\_CC.[peripherals name]})

1. CC = 0b00 : Peripheral clocks are disabled; module does not stall low power mode entry. Clock is always gated, peripheral access causes hard fault.
2. CC = 0b01 : Peripheral clocks are enabled; module does not stall low power mode entry. Clock is never gated unless root clock source is gated in DEEPSLEEP mode.

set CC=0b10 or CC=0b11 when using async DMA/interrupt of LPUART, LPSPI, LPI2C, FLEXIO and GPIO in DEEPSLEEP0 mode.

3. CC = 0b10 : Peripheral clocks are enabled unless module is idle; low power mode entry stalls until module is idle. Only LPUART, LPSPI, LPI2C, FLEXIO, GPIO, FMU support CC=0b10. for other modules, it's same as CC=0b11.
4. CC = 0b11 : Peripheral clocks are enabled unless in DEEPSLEEP (or lower) mode; low power mode entry stalls until module is idle.

# Chapter 15

## Enhanced DMA Controller (eDMA)

### 15.1 Chip-specific eDMA information

Table 74. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | eDMA           | <a href="#">eDMA</a>                |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 15.1.1 Module instances

This device has one 4-channel eDMA controller.

#### 15.1.2 Direct Memory Access Multiplexer (DMAMUX)

The peripheral request line for each channel of the Direct Memory Access Controller (DMA) is driven from a Direct Memory Access Multiplexer (DMAMUX). This is a flexible configuration that allows the user to select the appropriate peripheral to connect to each channel of the DMA Controller. The DMAMUX for this device allows up to 66 DMA request signals (30 unused signals are reserved) to be mapped to each channel. Because of the mux, there is not a correlation between any of the DMA request sources and a specific DMA channel.

The DMAMUX is an integrated component of the DMA Controller.

##### 15.1.2.1 DMAMUX0 Request Assignments

See the attached DMA\_Configuration spreadsheet to know the DMA channel and source assignments for DMAMUX0.

## 15.2 Overview

The enhanced direct memory access (eDMA) controller is capable of performing complex data transfers with minimal intervention from a host processor. The hardware microarchitecture includes:

- A DMA engine that performs:
  - Source address and destination address calculations
  - Data-movement operations
- Local memory containing transfer control descriptors for each of the 4 channels

### 15.2.1 Block diagram

[Figure 17](#) illustrates the components of the eDMA system, including the eDMA module (engine).



Figure 17. Block diagram

### 15.2.2 Block parts

The eDMA module is partitioned into two major modules: the eDMA engine and the transfer control descriptor local memory.

The eDMA engine is further partitioned into four submodules:

Table 75. eDMA engine submodules

| Submodule    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Address path | <p>This block:</p> <ul style="list-style-type: none"> <li>Implements a primary channel and secondary (preempt) channel</li> <li>Manages all master bus-address calculations</li> </ul> <p>All the channels provide the same functionality. This structure allows data transfers associated with one channel to be preempted after the completion of a read/write sequence if a higher priority channel activation is asserted while the primary channel is active.</p> <p>After a channel is activated, it runs until the minor loop is completed, unless preempted by a higher priority channel. This provides a mechanism (enabled by CHn_PRI[ECP]) where a large data transfer can be preempted to minimize the time another channel is blocked from execution.</p> |

*Table continues on the next page...*

**Table 75.** eDMA engine submodules (continued)

| Submodule                         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                   | When any channel is selected to execute, the contents of its TCD are read from local memory and loaded into the address path channel x registers for a normal start and into channel y registers for a preemption start. After the minor loop completes execution, the address path hardware writes the new values for the TCD $n$ _{SADDR, DADDR, CITER} back to local memory. If the major iteration count is exhausted, additional processing is performed, including the final address pointer updates, reloading the TCD $n$ _CITER field, and a possible fetch of a new TCD $n$ from memory as part of a scatter/gather operation. See <a href="#">Dynamic scatter/gather</a> for more details. |
| Data path                         | This block implements the bus master read/write data path. It includes a data buffer and the necessary multiplex logic to support any required data alignment. The internal read data bus is the primary input, and the internal write data bus is the primary output.<br><br>The address and data path modules directly support the 2-stage pipelined internal bus. The address path module represents the first stage of the bus pipeline (address phase), and the data path module implements the second stage of the pipeline (data phase).                                                                                                                                                       |
| Program model/channel arbitration | This block implements the first section of the eDMA programming model as well as the channel arbitration logic. The programming model registers are connected to the internal peripheral bus. The eDMA peripheral request inputs and interrupt request outputs are also connected to this block (via control logic).                                                                                                                                                                                                                                                                                                                                                                                  |
| Control                           | This block provides all the control functions for the eDMA engine. For data transfers where the source and destination sizes are equal, the eDMA engine performs a series of source read/destination write operations until the number of bytes specified in the minor loop byte count has been moved from the source to the destination.<br><br>For descriptors where the sizes are not equal, multiple accesses of the smaller size data are required for each reference of the larger size. As an example, if the source size references 16-bit data and the destination is 32-bit data, the eDMA performs two reads, then one 32-bit write.                                                       |

The transfer control descriptor local memory is further partitioned into:

**Table 76.** Transfer control descriptor memory

| Submodule         | Description                                                                                                                                                                                                                                                         |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Memory controller | This logic implements the required dual-ported controller, and manages accesses from the eDMA engine as well as references from the internal peripheral bus. In simultaneous accesses, the eDMA engine is given priority and the peripheral transaction is stalled. |
| Memory array      | TCD storage for each channel's transfer profile.                                                                                                                                                                                                                    |

### 15.2.3 Features

The eDMA is a highly programmable data-transfer engine optimized to minimize any required intervention from the host processor. It is intended for use in applications where the data size to be transferred is statically known and is not defined within the transferred data itself. The eDMA module features:

- All data movement via dual-address transfers: read from source, write to destination
  - Programmable source and destination addresses and transfer size
  - Support for complex address calculations
- 4-channel implementation that performs complex data transfers with minimal intervention from a host processor
  - Internal data buffer, used as temporary storage for all transfers

- Connections to the crossbar switch for bus mastering the data movement
- TCD organized to support two-deep, nested transfer operations
  - 32-byte TCD stored in local memory for each channel
  - An inner data transfer loop defined by a minor byte transfer count
  - An outer data transfer loop defined by a major iteration count
- Channel activation via one of three methods:
  - Explicit software initiation
  - Initiation via a channel-to-channel linking mechanism for continuous transfers
  - Peripheral-paced hardware requests, one per channel
- Fixed-priority and round-robin channel arbitration
- Channel completion reported via programmable interrupt requests
  - One interrupt per channel, which can be asserted at completion of major iteration count
  - Programmable error terminations per channel that are logically summed together to form one error interrupt to the interrupt controller
- Programmable support for scatter/gather DMA processing
- Support for complex data structures

In the discussion of this module,  $n$  is used to reference the channel number.

### 15.3 Functional description

The operation of eDMA is described in the following subsections.

#### 15.3.1 Modes of operation

The eDMA operates in the following modes:

**Table 77. Modes of operation**

| Mode   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Normal | <p>In Normal mode, eDMA transfers data between a source and a destination. The source and destination can be a memory block or an I/O block capable of operation with eDMA.</p> <p>A service request initiates a transfer of a specific number of bytes (NBYTES) as specified in the TCD. The minor loop is the sequence of read-write operations that transfers these NBYTES per service request. Each service request executes one iteration of the major loop, which transfers NBYTES of data.</p> |
| Debug  | <p>eDMA operation is configurable in Debug mode via the control register:</p> <ul style="list-style-type: none"> <li>• If CSR[EDBG] is cleared to 0, eDMA continues to operate.</li> <li>• If CSR[EDBG] is set to 1, eDMA stops transferring data. If Debug mode is entered when a channel is active, eDMA continues operation until the channel retires.</li> </ul>                                                                                                                                  |

#### 15.3.2 eDMA basic data flow

The basic flow of a data transfer can be partitioned into three segments.

As shown in the following diagram, the first segment involves the channel activation:



Figure 18. eDMA operation, part 1

This example uses the assertion of the eDMA peripheral request signal to request service for channel  $n$ . Channel activation via software and the TCD $n$ \_CSR[START] field follows the same basic flow as peripheral requests. The eDMA request input signal is registered internally and then routed through the eDMA engine: first through the control module, then into the program model and channel arbitration.

In the next cycle, the channel arbitration begins using fixed-priority plus the optional round-robin algorithm. After arbitration is complete, the activated channel number is sent through the address path and converted into the required address to access the local memory for TCD $n$ . Next, the TCD memory is accessed and the required descriptor is read from the local memory and then loaded into the eDMA engine address path's primary or secondary channel execution registers. The TCD memory is 64 bits wide to minimize the time needed to fetch the activated channel descriptor and load it into the address path registers.

The following diagram illustrates the second part of the basic data flow:



The modules associated with the data transfer (address path, data path, and control) go through the required sequence of source reads and destination writes to perform the actual data movement. The source reads are initiated, and the fetched data is temporarily stored in the data path block until it is gated onto the internal bus during the destination write. This source read/destination write processing continues until the byte count, NBYTES, has been transferred.

After NBYTES of data has been moved, the final phase of the basic data flow is performed. In this segment, the address path logic performs the required updates to certain fields in the appropriate TCD (for example, SADDR, DADDR, CITER). If the major iteration count is exhausted, additional operations are performed. These include the final address adjustments and reloading of the BITER field into the CITER field. Assertion of an optional interrupt request also occurs at this time, as does a possible fetch of a new TCD from memory using the scatter/gather address pointer included in the descriptor (if scatter/gather is enabled). The updates to the TCD memory and the assertion of an interrupt request are shown in the following diagram.



Figure 20. eDMA operation, part 3

### 15.3.3 Fault reporting and handling

Channel errors are reported in the Error Status register ([CHn\\_ES](#)) and can be caused by any of the following:

- A configuration error, which is an illegal setting in the transfer control descriptor
- An active channel canceled via a "cancel transfer with error" hardware or software request
- An error termination to a bus master read or write cycle

A configuration error is reported when an inconsistent state is represented by one of these factors:

- Starting source or destination address
- Source or destination offsets
- Minor loop byte count
- Transfer size

Each of these possible causes is detailed below:

- The addresses and offsets must be aligned on zero-modulo-transfer-sized boundaries.
- The minor loop byte count must be a multiple of the source and destination transfer sizes.
- All source reads and destination writes must be configured to the natural boundary of the programmed transfer size.

**NOTE**

To aid in debugging, set the Halt After Error field in the DMA's Control Status register, CSR[HAE]. Upon any error condition, the DMA is halted after the error is recorded. The DMA remains halted and does not process any channel service requests. After the error is fixed, the DMA may be enabled again by clearing the Halt field, CSR[HALT].

- If a scatter/gather operation is enabled upon channel completion, a configuration error is reported if the scatter/gather address (TCDn\_DLAST\_SGA) is not aligned on a 32-byte boundary.
- If minor loop channel linking is enabled upon channel completion, a configuration error is reported when the link is attempted if the TCDn\_CITER[ELINK] field does not equal the TCDn\_BITER[ELINK] field.

If enabled, all configuration error conditions, except the scatter/gather and minor-loop link errors, are reported as the channel activates and asserts an error interrupt request. A scatter/gather configuration error is reported when the scatter/gather operation begins at major loop completion if properly enabled. A minor loop channel link configuration error is reported when the link operation is serviced at minor loop completion.

If a system bus read or write is terminated with an error, the data transfer is stopped and the appropriate bus error flag set. In this case, the state of the channel's transfer control descriptor is updated by the eDMA engine with the current source address, destination address, and current iteration count at the point of the fault. When a system bus error occurs, the channel terminates after the next transfer. Due to pipeline effect, the next transfer is already in progress when the bus error is received by the eDMA. If a bus error occurs on the last read prior to beginning the write sequence, the write executes using the data captured during the bus error. If a bus error occurs on the last write prior to switching to the next read sequence, the read sequence executes before the channel terminates due to the destination bus error.

The occurrence of any error causes the eDMA engine to stop normal processing of the active channel immediately (it goes to its error processing states and the transaction to the system bus still has pipeline effect), and the appropriate channel field in the eDMA error register is set to 1. At the same time, the details of the error condition are loaded into the Error Status register (**CHn\_ES**). The major loop complete indicators, setting the transfer control descriptor DONE flag, and the possible assertion of an interrupt request are not affected when an error is detected.

After the error status has been updated, the eDMA engine continues operating by servicing the next appropriate channel. A channel that experiences an error condition is not automatically disabled. If a channel is terminated by an error and then issues another service request before the error is fixed, that channel executes and terminates with the same error condition.

The error status fields are read-only. These error indicators are sticky and cannot be cleared. They show the last recorded error until the DMA is reset. **CHn\_ES[ERR]** is used to determine if a new error condition exists. This field is the logical OR of each channel's error interrupt field (ERR).

After the software has resolved all errors and cleared all of the error interrupt fields, the **MP\_ES[VLD]** is cleared to 0 but the cause of the last error is still indicated.

#### 15.3.4 Channel preemption

The eDMA uses a priority vector value to determine the highest priority channel requesting service.

The priority vector is a combination of:

1. the channel's group priority, CHn\_GRPRI
2. the channel's priority level, CHn\_PRI[APL]

It can be considered a number composed of these concatenated priority levels: CHn\_GRPRI : CHn\_PRI[APL]

Priority vector = ((CHn\_GRPRI << 8) + (CHn\_PRI[APL] << 5) + CHn\_\*)

A channel requesting service with the highest priority vector value will receive the next execution slot.

An execution slot is available:

1. immediately if the eDMA is idle
2. when an active channel retires
3. when valid preemption conditions exist

---

**NOTE**

Preemption is strictly priority based. Preemption is not bound by a specific group number as defined by CHn\_GRPRI.

---

Channel preemption is enabled on a per-channel basis by setting the CHn\_PRI[ECP] field. Channel preemption allows the executing channel's data transfers to temporarily suspend in favor of starting a higher-priority channel. After the preempting channel has completed all of its minor loop data transfers, the preempted channel is restored and resumes execution.

After the restored channel completes one read/write sequence, it is again eligible for preemption. If any higher priority channel is requesting service, the restored channel is suspended, and the higher-priority channel is serviced. Nested preemption, that is, attempting to preempt a preempting channel, is not supported. After a preempting channel begins execution, it cannot be preempted.

A channel's ability to preempt another channel can be disabled by setting CHn\_PRI[DPA] to 1. When a channel's preempt ability is disabled, that channel cannot suspend a lower-priority channel's data transfer, regardless of the lower-priority channel's ECP setting. This allows for a pool of low-priority, large-data-moving channels to be defined.

You can configure these low-priority channels to not preempt each other, thus preventing a low-priority channel from consuming the preempt slot normally available to a true high-priority channel. When you enable round-robin channel arbitration mode (CSR[ERCA] is set to 1), any channel with a priority level equal to 0 (CHn\_PRI[APL] = 0) has preemption disabled and cannot preempt another channel.

### 15.3.5 Clocking

This module has no clocking considerations.

### 15.3.6 Interrupts

Software can enable the interrupt for each channel for the following events:

1. The major loop is half complete ([INTHALF](#))
2. The major loop is complete ([INTMAJOR](#))
3. A configuration error occurs ([EEI](#))

## 15.4 External signals

This module has no external signals.

## 15.5 Initialization

The following sections discuss initialization of the eDMA and programming considerations.

### 15.5.1 eDMA initialization

To initialize the eDMA:

1. Write to the [MP\\_CSR](#) if a configuration other than the default is wanted.
2. Write the channel priority levels to the [CHn\\_PRI](#) registers and group priority levels to the [CHn\\_GRPRI](#) registers if a configuration other than the default is wanted.
3. Enable error interrupts in the [CHn\\_CSR\[EEI\]](#) registers if they are wanted.
4. Write the 32-byte TCD for each channel that may request service.
5. Enable any hardware service requests via the [CHn\\_CSR\[ERQ\]](#) registers.
6. Request channel service via either:
  - Software: setting [TCDn\\_CSR\[START\]](#)
  - Hardware: slave device asserting its eDMA peripheral request signal

After any channel requests service, a channel is selected for execution based on the arbitration and priority levels written into the programmer's model. The eDMA engine reads the entire TCD, including the TCD control and status fields, as shown in [Table 78](#), for the selected channel into its internal address path module.

As the TCD is read, the first transfer is initiated on the internal bus, unless a configuration error is detected. Transfers from the source, defined by TCDn\_SADDR, to the destination, defined by TCD\_DADDR, continue until the number of bytes specified by TCDn\_NBYTES are transferred.

When the transfer is complete, the eDMA engine's local TCDn\_SADDR, TCDn\_DADDR, and TCDn\_CITER are written back to the main TCD memory and any minor loop channel linking is performed, if enabled. If the major loop is exhausted, then eDMA executes further post-processing, such as interrupts, major loop channel linking, and scatter/gather operations, if enabled.

**Table 78. TCD control and status (TCDn\_CSR) fields**

| TCDn_CSR field name | Description                                                                                                                   |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------|
| START               | Control field to start the channel explicitly when using a software-initiated DMA service (automatically cleared by hardware) |
| EEOP                | Control field to enable end-of-packet processing                                                                              |
| ESDA                | Control field to enable storing of the destination address to system memory after the major loop completes                    |
| DREQ                | Control field to disable hardware-initiated DMA service requests after major loop completion                                  |
| BWC                 | Control field for throttling the bandwidth control of a channel                                                               |
| ESG                 | Control field to enable the scatter-gather feature                                                                            |
| INTHALF             | Control field to enable interrupt when major loop is half-complete                                                            |
| INTMAJOR            | Control field to enable interrupt when major loop completes                                                                   |

**Table 79. Channel control and status (CHn\_CSR) fields**

| CHn_CSR field name | Description                                                                                         |
|--------------------|-----------------------------------------------------------------------------------------------------|
| ACTIVE             | Status field indicating the channel is currently in execution                                       |
| DONE               | Status field indicating major loop completion (cleared by software when a channel begins execution) |
| EEI                | Control field to enable error interrupts                                                            |
| EARQ               | Control field to enable external, asynchronous wakeup event in conjunction with the ERQ field       |
| ERQ                | Control field to enable hardware service requests                                                   |

The following figure shows how each DMA request initiates one minor-loop transfer, or iteration, without CPU intervention. DMA arbitration can occur after each minor loop, and one level of minor loop DMA preemption is allowed. The number of minor loops in a major loop is specified by the beginning iteration count (BITER).



Figure 21. Example of multiple loop iterations

The following figure lists the memory array terms and how the TCD settings are related.



Figure 22. Memory array terms

### 15.5.2 eDMA arbitration

The eDMA uses a layered arbitration scheme composed of multiple priority levels. The eDMA uses a fixed-priority arbitration scheme with optional round-robin arbitration under specific conditions. The priorities are evaluated in the following order:

Table 80. eDMA arbitration priorities

| Priority    | Scheme                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 (Highest) | Arbitration group priority | Each channel is assigned an arbitration group via the <a href="#">CHn_GRPRI</a> registers. Priority is given to the highest value (31 being the highest possible value) down to the lowest value (zero, the default).                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2           | Channel priority           | Each channel is assigned a channel priority level via the <a href="#">CHn_PRI</a> registers. The channel priority is a relative priority level within an arbitration group. Priority is given to the highest value (seven being the highest possible value) down to the lowest value (zero, the default). Channel priorities within each arbitration group need not be unique. If multiple channels have the same channel priority level, the channel number will be used to determine priority as defined in row three.                                                                                                                            |
| 3           | Channel number             | When two or more channels have the same arbitration group priority and channel priority, the channel number (CHn_NUM) is used to determine the highest priority. Priority is given to the highest channel number. Lowest priority is channel 0. The channel numbers are static and cannot be changed in the programmer's model.                                                                                                                                                                                                                                                                                                                     |
| 4 (Lowest)  | Round-robin                | When round-robin is enabled, any channel configured for round-robin operation has lowest priority within an arbitration group. Round-robin is enabled by setting the <a href="#">MP_CSR[ERCA]</a> field to 1. After being enabled, channels with a channel priority of zero (CHn_PRI=0) will use round-robin arbitration. Round-robin arbitration will rotate the channel selection among the channels requesting service with CHn_PRI=0 within the arbitration group. Any non-zero channel within the arbitration group will continue to use fixed-priority arbitration, and if requesting service will be selected over any round-robin channels. |

For fixed arbitration, the overall priority can be considered a number composed of three concatenated priority levels: [CHn\\_GRPRI](#):[CHn\\_PRI](#):[CH\\_NUM](#). The largest number has the highest priority and the lowest number has the lowest priority.

For round-robin arbitration, the priority number is [CHn\\_GRPRI](#):0:X. The module rotates through the [CHn\\_PRI](#)=0 channels requesting service without regard to priority among these channels. Any channel within the arbitration group for which [CHn\\_PRI](#) is greater than 0 will be serviced before the round-robin channels.

### 15.5.3 Programming errors

The eDMA performs various tests on the transfer control descriptor to verify consistency in the descriptor data.

The channel number causing the error is recorded in the Error Status register ([CHn\\_ES](#)). If the error source is not removed before the next activation of the problematic channel, the error is detected and recorded again. Setting the halt after error field, CSR[HAE], will halt the DMA and prevent recurrence of the error.

### 15.5.4 Arbitration mode considerations

This section discusses arbitration considerations for eDMA.

#### 15.5.4.1 Fixed group arbitration, fixed channel arbitration

In this mode, eDMA selects for execution the channel service request from the highest-priority channel in the highest-priority group. If eDMA is programmed so that the channels within a high-priority group have a high number of requests or large data transfers, that group may consume all the bandwidth of the eDMA controller. That is, no lower-priority groups are serviced if there is always at least one DMA request pending on a channel in the highest-priority group when the controller arbitrates the next DMA request. The advantage of this scenario is that latency can be small for channels that need to be serviced quickly.

#### 15.5.4.2 Fixed group arbitration, round-robin channel arbitration

The highest-priority group with a request is serviced. Lower-priority groups are serviced if no pending requests exist in the higher-priority groups.

Within each group, channels are serviced starting with the highest non-zero channel priority. For all channels with a channel priority programmed to 0, selection begins with the highest channel number requesting service and then rotates through to the lowest channel number requesting service. The round-robin channel arbitration can provide a fairness mechanism to lower-priority channels.

This scenario could cause the same bandwidth consumption problem as indicated in [Fixed group arbitration, fixed channel arbitration](#), but all the channels in the highest-priority group will be serviced. Service latency is short on the highest-priority group, but could potentially be very much longer as the group priority decreases.

### 15.5.5 Performing DMA transfers

This section presents examples on how to perform DMA transfers with the eDMA.

#### 15.5.5.1 Single request

To perform a simple transfer of n bytes of data with one activation, set the major loop to one (TCDn\_CITER = TCDn\_BITER = 1). The data transfer begins after the channel service request is acknowledged and the channel is selected to execute. After the transfer is complete, the CHn\_CSR[DONE] field is set to 1 and an interrupt is generated if properly enabled.

For example, the following TCD entry is configured to transfer 16 bytes of data. The eDMA is programmed for one iteration of the major loop transferring 16 bytes per iteration. The source memory has a byte-wide memory port located at 0x1000. The destination memory has a 32-bit port located at 0x2000. The address offsets are programmed in increments to match the transfer size: one byte for the source, and four bytes for the destination. The final source and destination addresses are adjusted to return to their beginning values.

```

TCDn_CITER = TCDn_BITER = 1
TCDn_NBYTES = 16
TCDn_SADDR = 0x1000
TCDn_SOFF = 1
TCDn_ATTR [SSIZE] = 0
TCDn_SLAST = -16
TCDn_DADDR = 0x2000
TCDn_DOFF = 4
TCDn_ATTR [DSIZE] = 2

```

```

TCDn_DLAST_SGA= -16
TCDn_CSR[INTMAJ] = 1
TCDn_CSR[START] = 1 (should be written last after all other fields have been initialized)
All other TCDn fields = 0

```

This generates the following event sequence:

1. User write to the TCD*n*\_CSR[START] field requests channel service.
2. The channel is selected by arbitration for servicing.
3. eDMA engine writes:
  - CH*n*\_CSR[DONE] = 0
  - TCD*n*\_CSR[START] = 0
  - CH*n*\_CSR[ACTIVE] = 1
4. eDMA engine reads: channel TCD data from local memory to internal register file.
5. The source-to-destination transfers are executed as follows:
  - a. Read byte from location 0x1000, read byte from location 0x1001, read byte from 0x1002, read byte from 0x1003.
  - b. Write 32 bits to location 0x2000 → first iteration of the minor loop.
  - c. Read byte from location 0x1004, read byte from location 0x1005, read byte from 0x1006, read byte from 0x1007.
  - d. Write 32 bits to location 0x2004 → second iteration of the minor loop.
  - e. Read byte from location 0x1008, read byte from location 0x1009, read byte from 0x100A, read byte from 0x100B.
  - f. Write 32 bits to location 0x2008 → third iteration of the minor loop.
  - g. Read byte from location 0x100C, read byte from location 0x100D, read byte from 0x100E, read byte from 0x100F.
  - h. Write 32 bits to location 0x200C → last iteration of the minor loop → major loop complete.
6. The eDMA engine writes: TCD*n*\_SADDR = 0x1000, TCD*n*\_DADDR = 0x2000, TCD*n*\_CITER = 1 (TCD*n*\_BITER).
7. The eDMA engine writes: CH*n*\_CSR[ACTIVE] = 0, CH*n*\_CSR[DONE] = 1, CH*n*\_INT[INT] = 1.
8. The channel retires and the eDMA goes idle or services the next channel.

### 15.5.5.2 Multiple requests

The following example transfers 32 bytes via two hardware requests, but is otherwise the same as the previous example. The only fields that change are the major loop iteration count and the final address offsets. The eDMA is programmed for two iterations of the major loop, transferring 16 bytes per iteration. After the channel's hardware requests are enabled via the CH*n*\_CSR[ERQ] register field, the slave device initiates channel service requests.

```

TCDn_CITER = TCDn_BITER = 2
TCDn_SLAST = -32
TCDn_DLAST_SGA = -32

```

This would generate the following sequence of events:

1. First hardware (eDMA peripheral) requests channel service.
2. The channel is selected by arbitration for servicing.
3. eDMA engine writes: CH*n*\_CSR[DONE] = 0, TCD*n*\_CSR[START] = 0, CH*n*\_CSR[ACTIVE] = 1.
4. eDMA engine reads: channel TCD*n* data from local memory to internal register file.
5. The source-to-destination transfers are executed as follows:

- a. Read byte from location 0x1000, read byte from location 0x1001, read byte from 0x1002, read byte from 0x1003.
  - b. Write 32 bits to location 0x2000 → first iteration of the minor loop.
  - c. Read byte from location 0x1004, read byte from location 0x1005, read byte from 0x1006, read byte from 0x1007.
  - d. Write 32 bits to location 0x2004 → second iteration of the minor loop.
  - e. Read byte from location 0x1008, read byte from location 0x1009, read byte from 0x100A, read byte from 0x100B.
  - f. Write 32 bits to location 0x2008 → third iteration of the minor loop.
  - g. Read byte from location 0x100C, read byte from location 0x100D, read byte from 0x100E, read byte from 0x100F.
  - h. Write 32 bits to location 0x200C → last iteration of the minor loop.
6. eDMA engine writes:  $TCDn\_SADDR = 0x1010$ ,  $TCDn\_DADDR = 0x2010$ ,  $TCDn\_CITER = 1$ .
  7. eDMA engine writes:  $CHn\_CSR[ACTIVE] = 0$ .
  8. The channel retires, which concludes one iteration of the major loop. The eDMA goes idle or services the next channel.
  9. Second hardware (eDMA peripheral) requests channel service.
  10. The channel is selected by arbitration for servicing.
  11. eDMA engine writes:  $CHn\_CSR[DONE] = 0$ ,  $TCDn\_CSR[START] = 0$ ,  $CHn\_CSR[ACTIVE] = 1$ .
  12. eDMA engine reads: Channel TCD data from local memory to internal register file.
  13. The source-to-destination transfers are executed as follows:
    - a. Read byte from location 0x1010, read byte from location 0x1011, read byte from 0x1012, read byte from 0x1013.
    - b. Write 32 bits to location 0x2010 → first iteration of the minor loop.
    - c. Read byte from location 0x1014, read byte from location 0x1015, read byte from 0x1016, read byte from 0x1017.
    - d. Write 32 bits to location 0x2014 → second iteration of the minor loop.
    - e. Read byte from location 0x1018, read byte from location 0x1019, read byte from 0x101A, read byte from 0x101B.
    - f. Write 32 bits to location 0x2018 → third iteration of the minor loop.
    - g. Read byte from location 0x101C, read byte from location 0x101D, read byte from 0x101E, read byte from 0x101F.
    - h. Write 32 bits to location 0x201C → last iteration of the minor loop → major loop complete.
  14. eDMA engine writes:  $TCDn\_SADDR = 0x1000$ ,  $TCDn\_DADDR = 0x2000$ ,  $TCDn\_CITER = 2$  ( $TCDn\_BITER$ ).
  15. eDMA engine writes:  $CHn\_CSR[ACTIVE] = 0$ ,  $CHn\_CSR[DONE] = 1$ ,  $CHn\_INT[INT] = 1$ .
  16. The channel retires, which concludes with the major loop complete. The eDMA goes idle or services the next channel.

### 15.5.5.3 Using the modulo feature

The modulo feature of the eDMA allows implementation of a circular data queue in which the size of the queue is a power of 2. xMOD is a 5-bit field for the source and destination in the TCD, and it specifies which lower address bits increment from their original value after the address+offset calculation. All upper address bits remain the same as in the original value. A setting of 0 for this field disables the modulo feature. Modulo addressing applies to cases where the minor loop offset is enabled; that is, the upper address bits remain the same after the minor loop offset is added to the source or destination address.

The following table shows how the transfer addresses are specified based on the setting of the MOD field. Here a circular buffer is created where the address wraps to the original value but the 28 upper address bits (0x1234567 $x$ ) retain their original value. In this example, the source address is set to 0x12345670, the offset is set to four bytes, and the MOD field is set to four, which allows for a  $2^4$  byte (16 byte) queue size.

**Table 81. Modulo example**

| Transfer number | Address    |
|-----------------|------------|
| 1               | 0x12345670 |
| 2               | 0x12345674 |
| 3               | 0x12345678 |
| 4               | 0x1234567C |
| 5               | 0x12345670 |
| 6               | 0x12345674 |

## 15.5.6 Monitoring transfer descriptor status

This section discusses how to monitor eDMA status.

### 15.5.6.1 Testing for minor loop completion

There are two methods to test for minor loop completion when using software-initiated service requests.

1. The first method is to read the TCDn\_CITER field and test for a change.
2. The second method, extracted from the sequence shown below, is to test the TCDn\_CSR[START] field and the CHn\_CSR[ACTIVE] field. The minor-loop-complete condition is indicated by both fields reading 0 after TCDn\_CSR[START] is set to 1. Polling the CHn\_CSR[ACTIVE] field only may be inconclusive because the active status may be missed if the channel execution is short in duration.

The [CHn\\_CSR](#) and [TCDn\\_CSR](#) status fields execute the following sequence for a software-activated channel:

| Stage | TCDn_CSR field | CHn_CSR fields |        |      | State                                             |
|-------|----------------|----------------|--------|------|---------------------------------------------------|
|       |                | START          | ACTIVE | DONE |                                                   |
| 1     | 1              | 0              | 0      | 0    | Initiate channel service request via software.    |
| 2     | 0              | 1              | 0      | 0    | Channel is executing.                             |
| 3a    | 0              | 0              | 0      | 0    | Channel has completed the minor loop and is idle. |
| 3b    | 0              | 0              | 1      | 1    | Channel has completed the major loop and is idle. |

The best method to test for minor-loop completion when using hardware-initiated (that is, peripheral-initiated) service requests is to read the TCDn\_CITER field and test for a change. The hardware request and acknowledge handshake signals are not visible in the programmer's model.

The TCD status fields execute the following sequence for a hardware-activated channel:

| Stage | TCDn_CSR field | CHn_CSR fields |        | State                                                                        |
|-------|----------------|----------------|--------|------------------------------------------------------------------------------|
|       |                | START          | ACTIVE |                                                                              |
| 1     | 0              | 0              | 0      | Initiate channel service request via hardware (peripheral request asserted). |
| 2     | 0              | 1              | 0      | Channel is executing.                                                        |
| 3a    | 0              | 0              | 0      | Channel has completed the minor loop and is idle.                            |
| 3b    | 0              | 0              | 1      | Channel has completed the major loop and is idle.                            |

For both activation types, the major-loop-complete status is explicitly indicated via the CHn\_CSR[DONE] field.

The TCDn\_CSR[START] field is cleared to 0 automatically when the channel begins execution, regardless of how the channel activates.

#### 15.5.6.2 Reading the transfer descriptors of active channels

The eDMA reads back the true TCDn\_SADDR, TCDn\_DADDR, and TCDn\_NBYTES values if they are read when a channel executes. The true values of SADDR, DADDR, and NBYTES are the values the eDMA engine currently uses in its internal register file, and not the values in the TCD local memory for that channel. The addresses, SADDR and DADDR, and NBYTES (which decrements to zero as the transfer progresses), can give an indication of the progress of the transfer. All other values are read back from the TCD local memory.

#### 15.5.6.3 Checking channel preemption status

A preemptive situation is one in which a preempt-enabled channel is executing and a higher-priority request becomes active. When round-robin channel arbitration mode is enabled, all channels with their channel priority set to 0 lose their preempt ability. Channel priorities of 0 are treated as equal, that is, they are constantly rotating, when round-robin arbitration mode is enabled.

The CHn\_CSR[ACTIVE] field for the preempted channel remains asserted throughout the preemption. The preempted channel is temporarily suspended when the preempting channel executes one major loop iteration. If two CHn\_CSR[ACTIVE] fields are set simultaneously in the global TCD map, a higher-priority channel is actively preempting a lower-priority channel.

#### 15.5.7 Channel linking

Channel linking (or chaining) is a mechanism in which one channel sets the TCDn\_CSR[START] field of another channel (or itself), thus initiating a service request for that channel. When properly enabled, the eDMA engine automatically performs this operation at the major or minor loop completion.

The minor loop channel linking occurs at the completion of the minor loop (or one iteration of the major loop). The TCDn\_CITER[ELINK] field determines whether a minor loop link is requested. When enabled, the channel link is made after each iteration of the major loop except for the last. When the major loop is exhausted, only the major loop channel link fields are used to determine if a channel link should be made. For example, using an initial field setting of:

```
MP_CSR [GCLC] = 1
TCDn_CITER [ELINK] = 1
TCDn_CITER [LINKCH] = 0xC
TCDn_CITER [CITER] value = 0x4
TCDn_CSR [MAJORELINK] = 1
TCDn_CSR [MAJORLINKCH] = 0x7
```

executes as:

1. Minor loop done → set TCD12\_CSR[START] field
2. Minor loop done → set TCD12\_CSR[START] field
3. Minor loop done → set TCD12\_CSR[START] field
4. Minor loop done, major loop done → set TCD7\_CSR[START] field

When minor loop linking is enabled ( $\text{TCDn\_CITER[ELINK]} = 1$ ), the  $\text{TCDn\_CITER[CITER]}$  field uses a nine-bit vector to form the current iteration count. When minor loop linking is disabled ( $\text{TCDn\_CITER[ELINK]} = 0$ ), the  $\text{TCDn\_CITER[CITER]}$  field uses a 15-bit vector to form the current iteration count. The bits associated with the  $\text{TCDn\_CITER[LINKCH]}$  field are concatenated onto the CITER value to increase the range of the CITER.

#### NOTE

The  $\text{TCDn\_CITER[ELINK]}$  field and the  $\text{TCDn\_BITER[ELINK]}$  field must be equal — if they are not, a configuration error is reported. The CITER and BITER vector widths must be equal to calculate the major loop halfway done interrupt point.

The following table summarizes how a DMA channel can link to another DMA channel, that is, use another channel's TCD, at the end of a loop.

**Table 82. Channel linking parameters**

| Wanted link behavior      | TCD control field name          | Description                                                                    |
|---------------------------|---------------------------------|--------------------------------------------------------------------------------|
| Link at end of minor loop | $\text{TCDn\_CITER[ELINK]}$     | Enable channel-to-channel linking on minor loop completion (current iteration) |
|                           | $\text{TCDn\_CITER[LINKCH]}$    | Link channel number when linking at end of minor loop (current iteration)      |
| Link at end of major loop | $\text{TCDn\_CSR[MAJORELINK]}$  | Enable channel-to-channel linking on major loop completion                     |
|                           | $\text{TCDn\_CSR[MAJORLINKCH]}$ | Link channel number when linking at end of major loop                          |

## 15.5.8 Dynamic programming

This section provides recommended methods to change the programming model during channel execution.

### 15.5.8.1 Dynamically changing the channel priority

To change group or channel priority levels:

1. Halt the DMA by writing 1 to the CSR[HALT] field.
2. Change the group or channel priorities as wanted.
3. Enable normal DMA operations by writing 0 to the CSR[HALT] field.

### 15.5.8.2 Dynamic channel linking

Dynamic channel linking is the process of setting the  $\text{TCDn\_CSR[MAJORELINK]}$  field during channel execution (see the diagram in [TCD structure](#)). This field is read from the TCD local memory at the end of channel execution, thus allowing you to enable the feature during channel execution.

Because you are allowed to change the configuration during execution, you need a coherency model. Consider the scenario where you attempt to execute a dynamic channel link by enabling the  $\text{TCDn\_CSR[MAJORELINK]}$  field at the same time the eDMA engine is retiring the channel.  $\text{TCDn\_CSR[MAJORELINK]}$  would be set in the programmer's model, but it would be unclear whether the actual link was made before the channel retired.

We recommend that you use the following coherency model when executing a dynamic channel link request.

1. Write 1 to the [TCDn\\_CSR\[MAJORELINK\]](#) field.
2. Read back the [TCDn\\_CSR\[MAJORELINK\]](#) field.
3. Test the [TCDn\\_CSR\[MAJORELINK\]](#) request status:
  - If [TCDn\\_CSR\[MAJORELINK\]](#) = 1, the dynamic link attempt was successful.
  - If [TCDn\\_CSR\[MAJORELINK\]](#) = 0, the attempted dynamic link did not succeed (the channel was already retiring).

For this request, the TCD local memory controller forces the [TCDn\\_CSR\[MAJORELINK\]](#) field to 0 on any writes to a channel's [TCDn\\_CSR\[7:0\]](#) after that channel's [CHn\\_CSR\[DONE\]](#) field is set to 1, indicating the major loop is complete.

---

**NOTE**

You must clear the [CHn\\_CSR\[DONE\]](#) field to 0 before writing to the [TCDn\\_CSR\[MAJORELINK\]](#) field. The [CHn\\_CSR\[DONE\]](#) field is cleared to 0 automatically by the eDMA engine after a channel begins execution.

---

#### 15.5.8.3 Dynamic scatter/gather

Scatter/gather is the process of automatically loading a new TCD into a channel. It allows a DMA channel to use multiple TCDs; this enables a DMA channel to scatter the DMA data to multiple destinations or gather it from multiple sources. When scatter/gather is enabled and the channel has finished its major loop, a new TCD is fetched from system memory and loaded into that channel's descriptor location in the eDMA programmer's model, thus replacing the current descriptor.

Because you are allowed to change the configuration during execution, you need a coherency model. Consider the scenario where you attempt to execute a dynamic scatter/gather operation by enabling the [TCDn\\_CSR\[ESG\]](#) field at the same time the eDMA engine is retiring the channel. The [TCDn\\_CSR\[ESG\]](#) field would be set in the programmer's model, but it would be unclear whether the actual scatter/gather request was honored before the channel retired.

Two methods are recommended for executing a dynamic scatter/gather request. Whenever the [TCDn\\_CSR](#) is written, the TCD local memory controller forces the [TCDn\\_CSR\[ESG\]](#) field to 0 on any writes to a channel's [TCDn\\_CSR\[7:0\]](#) after that channel's [CHn\\_CSR\[DONE\]](#) field has been set to 1, indicating the major loop is complete. If attempting to set the ESG, ensure the DONE field is cleared to 0.

---

**NOTE**

You must clear the [CHn\\_CSR\[DONE\]](#) field to 0 before writing the [TCDn\\_CSR\[MAJORELINK\]](#) or [TCDn\\_CSR\[ESG\]](#) fields. The [CHn\\_CSR\[DONE\]](#) field is cleared to 0 automatically by the eDMA engine after a channel begins execution and is set to 1 upon major loop completion.

---

##### 15.5.8.3.1 Method 1 (channel not using major loop channel linking)

For a channel not using major loop channel linking, the coherency model described here may be used for a dynamic scatter/gather request.

When the [TCDn\\_CSR\[MAJORELINK\]](#) field is 0, the [TCDn\\_CSR\[MAJORLINKCH\]](#) field is not used by the eDMA. In this case, the [TCDn\\_CSR\[MAJORLINKCH\]](#) bits may be used for other purposes. This method uses the [TCDn\\_CSR\[MAJORLINKCH\]](#) field as a [TCDn\\_CSR](#) identification (ID).

When the descriptors are built, write a unique [TCDn\\_CSR](#) ID in the [TCDn\\_CSR\[MAJORLINKCH\]](#) field for each [TCDn\\_CSR](#) associated with a channel using dynamic scatter/gather.

1. Write a 1 to the [TCDn\\_CSR\[DREQ\]](#) field. Should a dynamic scatter/gather attempt fail, setting the [TCDn\\_CSR\[DREQ\]](#) field to 1 will prevent future hardware activation of this channel. This stops the channel from executing with a destination address (daddr) that was calculated using a scatter/gather address (written in the next step) instead of a DLAST final offset value.
2. Write the [TCDn\\_DLAST\\_SGA](#) field with the scatter/gather address.
3. Write a 1 to the [TCDn\\_CSR\[ESG\]](#) field.
4. Read back the 16-bit [TCDn\\_CSR](#) control/status field.
5. Test the [TCDn\\_CSR\[ESG\]](#) request status and [TCDn\\_CSR\[MAJORLINKCH\]](#) value:

- If ESG = 1, the dynamic scatter/gather attempt was successful.
- If ESG = 0 and the MAJORLINKCH (ID) did not change, the dynamic scatter/gather attempt was not successful (the channel was already retiring).
- If ESG = 0 and the MAJORLINKCH (ID) changed, the dynamic scatter/gather attempt was successful (the new TCDn\_CSR's ESG value cleared the ESG field to 0).

### 15.5.8.3.2 Method 2 (channel using major loop channel linking)

For a channel using major loop channel linking, the coherency model described here may be used for a dynamic scatter/gather request. This method uses the [TCDn\\_DLAST\\_SGA](#) field as a TCD identification (ID).

1. Write a 1 to the [TCDn\\_CSR\[DREQ\]](#) field. Should a dynamic scatter/gather attempt fail, setting the DREQ field to 1 will prevent a future hardware activation of this channel. This stops the channel from executing with a destination address (DADDR) that was calculated using a scatter/gather address (written in the next step) instead of a DLAST final offset value.
2. Write the [TCDn\\_DLAST\\_SGA](#) field with the scatter/gather address.
3. Write a 1 to the [TCDn\\_CSR\[ESG\]](#) field.
4. Read back the [TCDn\\_CSR\[ESG\]](#) field.
5. Test the [TCDn\\_CSR\[ESG\]](#) request status:
  - If ESG = 1, the dynamic scatter/gather attempt was successful.
  - If ESG = 0, read the 32-bit [TCDn\\_DLAST\\_SGA](#) field.
  - If ESG = 0 and the [TCDn\\_DLAST\\_SGA](#) did not change, the dynamic scatter/gather attempt was not successful (the channel was already retiring).
  - If ESG = 0 and the [TCDn\\_DLAST\\_SGA](#) changed, the dynamic scatter/gather attempt was successful (the new TCDn\_CSR's ESG value cleared the ESG field to 0).

### 15.5.9 Suspend/resume a DMA channel with active hardware service requests

The DMA allows you to move data from memory or peripheral registers to another location in memory or to peripheral registers without CPU interaction. After the DMA and peripherals are configured and active, it is rare but supported to suspend a peripheral's service request dynamically. In this scenario, there are certain restrictions to disabling a DMA hardware service request. For coherency, you must follow a specific procedure. This section provides guidance on how to coherently suspend and resume a Direct Memory Access (DMA) channel when the DMA is triggered by a slave module such as the Serial Peripheral Interface (SPI), Sigma Delta Analog to Digital Convertor (SDADC), or other module.

#### 15.5.9.1 Suspend an active DMA channel

To suspend an active DMA channel:

1. Stop the DMA service request at the peripheral first. Confirm it has been disabled by reading back the appropriate register in the peripheral.
2. Check the DMA's Hardware Request Status ([MP\\_HRS](#)) to ensure there is no service request to the DMA channel being suspended. Then disable the hardware service request by clearing the ERQ field to 0 on the appropriate DMA channel.

For example, assume the SPI is set as a master for transmitting data via a DMA service request when the TXFIFO has an empty slot. The DMA will transfer the next command and data to the TXFIFO upon the request. If you need to suspend the DMA/SPI transfer loop, perform the following steps:

1. Disable the DMA service request at the source by writing 0 to DSPI\_RSER[TFFF\_RE]. Confirm that DSPI\_RSER[TFFF\_RE] is 0.
2. Ensure there is no DMA service request from the SPI by verifying that [MP\\_HRS\[HRS\]](#) is 0 for the appropriate channel. If no service request is present, disable the DMA channel by clearing the channel's ERQ field to 0. If a service request is present, wait until the request has been processed and the HRS field reads 0.

### 15.5.9.2 Resume a DMA channel

To resume a DMA channel:

1. Enable the DMA service request on the appropriate channel by setting its ERQ field to 1.
2. Enable the DMA service request at the peripheral.

## 15.6 Memory map/register definition

The eDMA programming model is partitioned into three parts:

1. The first part defines a number of registers providing overall control functions and is known as the management page.
2. The second part corresponds to the channel (CH) control, status, and configuration.
3. The third part corresponds to the local TCD memory.

### TCD memory

Each channel requires a 32-byte transfer control descriptor for defining the data movement operation. Each TCDn definition is presented as 11 registers of 16 or 32 bits. See [DMA TCD register descriptions](#) for details.

### TCD initialization

Prior to activating a channel, you must initialize its TCD with the appropriate transfer profile.

**TCD structure**

<sup>1</sup> The fields implemented in Word 2 depend on whether DMA\_CR[EMLM] is 0 or 1.

Figure 23. TCD structure

**Accesses to reserved memory and fields**

- Reading reserved fields in a register returns the value of zero.
- Writes to reserved fields in a register are ignored.
- Reading or writing a reserved memory location generates a bus error.

**15.6.1 DMA MP register descriptions****15.6.1.1 MP memory map**

eDMA\_0\_MP base address: 4008\_0000h

| Offset | Register                         | Width<br>(in bits) | Access | Reset value |
|--------|----------------------------------|--------------------|--------|-------------|
| 0h     | Management Page Control (MP_CSR) | 32                 | RW     | 0031_0000h  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset      | Register                                          | Width<br>(In bits) | Access | Reset value |
|-------------|---------------------------------------------------|--------------------|--------|-------------|
| 4h          | Management Page Error Status (MP_ES)              | 32                 | R      | 0000_0000h  |
| 8h          | Management Page Interrupt Request Status (MP_INT) | 32                 | R      | 0000_0000h  |
| Ch          | Management Page Hardware Request Status (MP_HRS)  | 32                 | R      | 0000_0000h  |
| 100h - 10Ch | Channel Arbitration Group (CH0_GRPRI - CH3_GRPRI) | 32                 | RW     | 0000_0000h  |

### 15.6.1.2 Management Page Control (MP\_CSR)

#### Offset

| Register | Offset |
|----------|--------|
| MP_CSR   | 0h     |

#### Function

The Management Page Control register defines the basic operating configuration of the DMA.

Arbitration uses a two-tier priority system; group and channel priority. The eDMA assigns each channel to a priority group. Group arbitration is fixed-priority and cannot be changed. Channel arbitration uses fixed priority and may be configured to use a selective round-robin scheme for specified channels within each priority group. For fixed-priority arbitration, eDMA selects for execution the highest priority channel requesting service in the highest priority arbitration group.

The channel priority registers assign the relative priorities within each arbitration group; see [CHn\\_PRI](#). All channels with a non-zero CHn\_PRI value use fixed-priority arbitration.

When you enable round-robin arbitration, all channels with channel priority set to zero do not have a priority and, of those channels requesting service, are cycled through (from high to low channel number) without regard to priority relative to each other within the same priority group. Any channel with a non-zero CHn\_PRI value automatically has a higher priority over the round-robin channels. A channel's priority group is assigned in [Channel Arbitration Group \(CH0\\_GRPRI - CH3\\_GRPRI\)](#).

#### NOTE

For correct operation, changes to the MP\_CSR[ERCA, GCLC, GMRC] fields must be performed when the DMA channels are inactive; that is, when the MP\_CSR[ACTIVE] field is 0.

**Diagram**

| Bits  | 31       | 30 | 29 | 28 | 27       | 26  | 25        | 24   | 23       | 22  | 21        | 20 | 19   | 18   | 17        | 16 |
|-------|----------|----|----|----|----------|-----|-----------|------|----------|-----|-----------|----|------|------|-----------|----|
| R     | ACTIVE   |    |    |    | Reserved |     | ACTIVE_ID |      | Reserved |     |           |    |      |      |           |    |
| W     |          |    |    |    |          |     |           |      |          |     |           |    |      |      |           |    |
| Reset | 0        | 0  | 0  | 0  | 0        | 0   | 0         | 0    | 0        | 0   | 1         | 1  | 0    | 0    | 0         | 1  |
| Bits  | 15       | 14 | 13 | 12 | 11       | 10  | 9         | 8    | 7        | 6   | 5         | 4  | 3    | 2    | 1         | 0  |
| R     | Reserved |    |    |    | CX       | ECX | GMRC      | GCLC | HALT     | HAE | Reserv ed |    | ERCA | EDBG | Reserv ed |    |
| W     | 0        |    |    |    | 0        | 0   | 0         | 0    | 0        | 0   | 0         | 0  | 0    | 0    | 0         | 0  |
| Reset | 0        | 0  | 0  | 0  | 0        | 0   | 0         | 0    | 0        | 0   | 0         | 0  | 0    | 0    | 0         | 0  |

**Fields**

| Field              | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>ACTIVE       | DMA Active Status<br><br>0b - eDMA is idle<br><br>1b - eDMA is executing a channel                                                                                                                                                                                                                                                                                                                                                                              |
| 30-26<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 25-24<br>ACTIVE_ID | Active Channel ID<br><br>This field identifies the channel number that is executing when the ACTIVE bit is 1.                                                                                                                                                                                                                                                                                                                                                   |
| 23-16<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15-10<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 9<br>CX            | Cancel Transfer<br><br>When set to 1, this field cancels the remaining data transfer, stops the executing channel, and forces the minor loop to finish. The cancel takes effect after the last write of the current read/write sequence. CX clears itself to 0 after the cancel has been honored. This cancel retires the channel normally as if the minor loop had been completed.<br><br>0b - Normal operation<br><br>1b - Cancel the remaining data transfer |
| 8<br>ECX           | Cancel Transfer With Error<br><br>Cancellation of the remaining data transfer is similar to that of the CX field. Execution of the channel is stopped and the minor loop is forced to finish. The cancellation takes effect after the last write of the current read/write sequence. The ECX field clears itself to 0 after the cancel is honored. In addition to                                                                                               |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                                                                                                                                                                         |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | <p>canceling the transfer, ECX treats the cancel as an error condition, thus updating <a href="#">Management Page Error Status (MP_ES)</a> and generating an optional error interrupt.</p> <p>0b - Normal operation<br/>1b - Cancel the remaining data transfer</p>                                                                              |
| 7<br>GMRC | <p>Global Master ID Replication Control</p> <p><b>NOTE</b><br/>If master ID replication is disabled, the privileged protection level (Supervisor mode) for DMA transfers is used.</p> <p>0b - Master ID replication disabled for all channels<br/>1b - Master ID replication available and controlled by each channel's CHn_SBR[EMI] setting</p> |
| 6<br>GCLC | <p>Global Channel Linking Control</p> <p>0b - Channel linking disabled for all channels<br/>1b - Channel linking available and controlled by each channel's link settings</p>                                                                                                                                                                    |
| 5<br>HALT | <p>Halt DMA Operations</p> <p>This field stalls the start of any new channels. Executing channels are allowed to complete. Channel execution resumes when this field is cleared to 0.</p> <p>0b - Normal operation<br/>1b - Stall the start of any new channels</p>                                                                              |
| 4<br>HAE  | <p>Halt After Error</p> <p>When this field is set to 1, any error causes the HALT field to be set to 1. Then all service requests are ignored until the HALT field is cleared to 0.</p> <p>0b - Normal operation<br/>1b - Any error causes the HALT field to be set to 1</p>                                                                     |
| 3<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                         |
| 2<br>ERCA | <p>Enable Round Robin Channel Arbitration</p> <p>0b - Round-robin channel arbitration disabled. Fixed priority arbitration used for channel selection<br/>1b - Round-robin channel arbitration enabled. Round-robin arbitration used for channel selection</p>                                                                                   |
| 1<br>EDBG | <p>Enable Debug</p> <p>When in debug mode, the DMA stalls the start of a new channel. Executing channels are allowed to complete. DMA resumes channel execution when the system exits debug mode or clears the EDBG field to 0.</p> <p>0b - Debug mode disabled. When in debug mode, the DMA continues to operate</p>                            |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field  | Function                                                                                  |
|--------|-------------------------------------------------------------------------------------------|
|        | 1b - Debug mode is enabled. When in debug mode, the DMA stalls the start of a new channel |
| 0<br>— | Reserved                                                                                  |

### 15.6.1.3 Management Page Error Status (MP\_ES)

#### Offset

| Register | Offset |
|----------|--------|
| MP_ES    | 4h     |

#### Function

The ES provides information concerning the last recorded channel error. Channel errors can be caused by:

- An illegal setting in the transfer control descriptor
- An error termination to a bus master read or write cycle
- An uncorrectable error that occurred when the device was accessing the TCD SRAM
- A "cancel transfer with error" request was made via the corresponding cancel transfer field or input signal

Upon any error condition, the software must initialize the TCD of the channel that contains the error, as it is in an incomplete state after an error. See [Fault reporting and handling](#) for more details.

#### Diagram

| Bits  | 31  | 30       | 29 | 28 | 27  | 26     | 25  | 24  | 23  | 22  | 21  | 20  | 19  | 18 | 17 | 16 |
|-------|-----|----------|----|----|-----|--------|-----|-----|-----|-----|-----|-----|-----|----|----|----|
| R     | VLD | Reserved |    |    |     | ERRCHN |     | 0   |     |     |     |     |     |    |    |    |
| W     |     |          |    |    |     |        |     |     |     |     |     |     |     |    |    |    |
| Reset | 0   | 0        | 0  | 0  | 0   | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0  | 0  | 0  |
| Bits  | 15  | 14       | 13 | 12 | 11  | 10     | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2  | 1  | 0  |
| R     | 0   |          |    |    | ECX | SAE    | SOE | DAE | DOE | NCE | SGE | SBE | DBE |    |    |    |
| W     |     |          |    |    |     |        |     |     |     |     |     |     |     |    |    |    |
| Reset | 0   | 0        | 0  | 0  | 0   | 0      | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0  | 0  | 0  |

#### Fields

| Field | Function                                              |
|-------|-------------------------------------------------------|
| 31    | Valid<br>Logical OR of all CHn_ES[ERR] status fields. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VLD             | 0b - No CHn_ES[ERR] fields are set to 1<br>1b - At least one CHn_ES[ERR] field is set to 1, indicating a valid error exists that software has not cleared                                                                                                                                                                                                                                 |
| 30-26<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                  |
| 25-24<br>ERRCHN | Error Channel Number or Canceled Channel Number<br>The channel number of the last recorded error or last recorded error-canceled transfer.                                                                                                                                                                                                                                                |
| 23-9<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                  |
| 8<br>ECX        | Transfer Canceled<br>The ECX operation is a management page function. When employed, the targeted channel's CHn_ES register reports an unspecified error; that is, only the CHn_ES[ERR] field is set to 1. The management page has full view of the error condition.<br>0b - No canceled transfers<br>1b - Last recorded entry was a canceled transfer by the error cancel transfer input |
| 7<br>SAE        | Source Address Error<br>When this field is 1, it indicates that TCDn_SADDR is inconsistent with TCDn_ATTR[SSIZE].<br>0b - No source address configuration error<br>1b - Last recorded error was a configuration error detected in the TCDn_SADDR field                                                                                                                                    |
| 6<br>SOE        | Source Offset Error<br>When this field is 1, it indicates that TCDn_SOFF is inconsistent with TCDn_ATTR[SSIZE].<br>0b - No source offset configuration error<br>1b - Last recorded error was a configuration error detected in the TCDn_SOFF field                                                                                                                                        |
| 5<br>DAE        | Destination Address Error<br>When this field is 1, it indicates that TCDn_DADDR is inconsistent with TCDn_ATTR[DSIZE].<br>0b - No destination address configuration error<br>1b - Last recorded error was a configuration error detected in the TCDn_DADDR field                                                                                                                          |
| 4<br>DOE        | Destination Offset Error<br>When this field is 1, it indicates that TCDn_DOFF is inconsistent with TCDn_ATTR[DSIZE].<br>0b - No destination offset configuration error<br>1b - Last recorded error was a configuration error detected in the TCDn_DOFF field                                                                                                                              |
| 3               | NBYTES/CITER Configuration Error                                                                                                                                                                                                                                                                                                                                                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NCE   | <p>This error indicates that one of the following has occurred:</p> <ul style="list-style-type: none"> <li>• TCDn_NBYTES is not a multiple of TCDn_ATTR[SSIZE] and TCDn_ATTR[DSIZE]</li> <li>• TCDn_CITER[CITER] is equal to zero</li> <li>• TCDn_CITER[ELINK] is not equal to TCDn_BITER[ELINK]</li> </ul> <p>0b - No NBYTES/CITER configuration error<br/>1b - The last recorded error was NBYTES equal to zero or a CITER not equal to BITER error.<br/>Last recorded error was a configuration error detected in the TCDn_NBYTES or TCDn_CITER fields</p> |
| 2     | Scatter/Gather Configuration Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| SGE   | <p>When this field is 1, it indicates that <a href="#">TCDn_DLAST_SGA</a> is not on a 32-byte boundary. This field is checked at the beginning of a scatter/gather operation after major loop completion if <a href="#">TCDn_CSR[ESG]</a> is enabled.</p> <p>0b - No scatter/gather configuration error<br/>1b - Last recorded error was a configuration error detected in the TCDn_DLAST_SGA field</p>                                                                                                                                                       |
| 1     | Source Bus Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| SBE   | <p>0b - No source bus error<br/>1b - Last recorded error was a bus error on a source read</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0     | Destination Bus Error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| DBE   | <p>0b - No destination bus error<br/>1b - Last recorded error was a bus error on a destination write</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

#### 15.6.1.4 Management Page Interrupt Request Status (MP\_INT)

##### Offset

| Register | Offset |
|----------|--------|
| MP_INT   | 8h     |

##### Function

This register shows the current state of the interrupt service requests for all eDMA channels.

**Diagram**

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

**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3-0<br>INT | Interrupt Request Status<br><br>The INT register presents the interrupt request status for each eDMA channel. Depending on the appropriate field setting in the transfer control descriptors, the eDMA engine generates an interrupt on data transfer completion or an error condition. The eDMA routes channel interrupt requests to the interrupt controller. During the interrupt service routine associated with any given channel, it is the software's responsibility to clear the appropriate field in the channel's interrupt request register, CHn_INT, thus negating the interrupt request.<br><br>0b - Interrupt request for corresponding channel not present<br>1b - Interrupt request for corresponding channel present |

**15.6.1.5 Management Page Hardware Request Status (MP\_HRS)****Offset**

| Register | Offset |
|----------|--------|
| MP_HRS   | Ch     |

**Function**

The hardware request status register (HRS) shows the current state of the hardware service request signaling as seen by eDMA's arbitration logic.

**Diagram**

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

**Fields**

| Field | Function                                                                                                                                                                                                                                                                  |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0  | Hardware Request Status                                                                                                                                                                                                                                                   |
| HRS   | The HRS bit for its respective channel remains asserted for the period when a hardware request is present on the channel.<br>0b - Hardware service request for corresponding channel is not present<br>1b - Hardware service request for corresponding channel is present |

**15.6.1.6 Channel Arbitration Group (CH0\_GRPRI - CH3\_GRPRI)****Offset**

| Register  | Offset |
|-----------|--------|
| CH0_GRPRI | 100h   |
| CH1_GRPRI | 104h   |
| CH2_GRPRI | 108h   |
| CH3_GRPRI | 10Ch   |

**Function**

The contents of this register define the arbitration group associated with each channel. Using a fixed-priority group arbitration scheme, eDMA evaluates the arbitration group priorities by numeric value from highest group number to lowest; for example, 0 is the lowest priority, 1 is the next higher priority, then 2, 3, and so on. The range of the group priority values is limited to the values of 0 through 31. Within each arbitration group, the channel priority assignment CH $n$ \_PRI determines the highest-priority channel.

**Diagram**

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

**Fields**

| Field        | Function                                                                    |
|--------------|-----------------------------------------------------------------------------|
| 31-5<br>—    | Reserved                                                                    |
| 4-0<br>GRPRI | Arbitration Group For Channel n<br>Fixed-priority arbitration group number. |

**15.6.2 DMA TCD register descriptions****15.6.2.1 TCD memory map**

eDMA\_0\_TCD0 base address: 4008\_1000h

| Offset      | Register                                                                                    | Width<br>(in bits) | Access | Reset value |
|-------------|---------------------------------------------------------------------------------------------|--------------------|--------|-------------|
| 0h - 3000h  | Channel Control and Status (CH0_CSR - CH3_CSR)                                              | 32                 | RW     | 0000_0000h  |
| 4h - 3004h  | Channel Error Status (CH0_ES - CH3_ES)                                                      | 32                 | RW     | 0000_0000h  |
| 8h - 3008h  | Channel Interrupt Status (CH0_INT - CH3_INT)                                                | 32                 | RW     | 0000_0000h  |
| Ch - 300Ch  | Channel System Bus (CH0_SBR - CH3_SBR)                                                      | 32                 | RW     | 0000_0005h  |
| 10h - 3010h | Channel Priority (CH0_PRI - CH3_PRI)                                                        | 32                 | RW     | 0000_0000h  |
| 14h - 3014h | Channel Multiplexor Configuration (CH0_MUX - CH3_MUX)                                       | 32                 | RW     | 0000_0000h  |
| 20h - 3020h | TCD Source Address (TCD0_SADDR - TCD3_SADDR)                                                | 32                 | RW     | See section |
| 24h - 3024h | TCD Signed Source Address Offset (TCD0_SOFF - TCD3_SOFF)                                    | 16                 | RW     | See section |
| 26h - 3026h | TCD Transfer Attributes (TCD0_ATTR - TCD3_ATTR)                                             | 16                 | RW     | See section |
| 28h - 3028h | TCD Transfer Size Without Minor Loop Offsets<br>(TCD0_NBYTES_MLOFFNO - TCD3_NBYTES_MLOFFNO) | 32                 | RW     | See section |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset      | Register                                                                                                        | Width<br>(In bits) | Access | Reset value                 |
|-------------|-----------------------------------------------------------------------------------------------------------------|--------------------|--------|-----------------------------|
| 28h - 3028h | TCD Transfer Size with Minor Loop Offsets<br>(TCD0_NBYTES_MLOFFYES - TCD3_NBYTES_MLOFFYES)                      | 32                 | RW     | <a href="#">See section</a> |
| 2Ch - 302Ch | TCD Last Source Address Adjustment / Store DADDR Address<br>(TCD0_SLAST_SDA - TCD3_SLAST_SDA)                   | 32                 | RW     | <a href="#">See section</a> |
| 30h - 3030h | TCD Destination Address (TCD0_DADDR - TCD3_DADDR)                                                               | 32                 | RW     | <a href="#">See section</a> |
| 34h - 3034h | TCD Signed Destination Address Offset (TCD0_DOFF - TCD3_DOFF)                                                   | 16                 | RW     | <a href="#">See section</a> |
| 36h - 3036h | TCD Current Major Loop Count (Minor Loop Channel Linking Disabled) (TCD0_CITER_ELINKNO - TCD3_CITER_ELINKNO)    | 16                 | RW     | <a href="#">See section</a> |
| 36h - 3036h | TCD Current Major Loop Count (Minor Loop Channel Linking Enabled) (TCD0_CITER_ELINKYES - TCD3_CITER_ELINKYES)   | 16                 | RW     | <a href="#">See section</a> |
| 38h - 3038h | TCD Last Destination Address Adjustment / Scatter Gather Address<br>(TCD0_DLAST_SGA - TCD3_DLAST_SGA)           | 32                 | RW     | <a href="#">See section</a> |
| 3Ch - 303Ch | TCD Control and Status (TCD0_CSR - TCD3_CSR)                                                                    | 16                 | RW     | <a href="#">See section</a> |
| 3Eh - 303Eh | TCD Beginning Major Loop Count (Minor Loop Channel Linking Disabled) (TCD0_BITER_ELINKNO - TCD3_BITER_ELINKNO)  | 16                 | RW     | <a href="#">See section</a> |
| 3Eh - 303Eh | TCD Beginning Major Loop Count (Minor Loop Channel Linking Enabled) (TCD0_BITER_ELINKYES - TCD3_BITER_ELINKYES) | 16                 | RW     | <a href="#">See section</a> |

### 15.6.2.2 Channel Control and Status (CH0\_CSR - CH3\_CSR)

#### Offset

| Register | Offset |
|----------|--------|
| CH0_CSR  | 0h     |
| CH1_CSR  | 1000h  |
| CH2_CSR  | 2000h  |
| CH3_CSR  | 3000h  |

#### Function

This register contains several fields related to hardware and interrupt requests, configuration, and status for the given channel.

**Diagram**

| Bits  | 31     | 30   | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19  | 18  | 17   | 16  |
|-------|--------|------|----|----|----|----|----|----|----|----|----|----|-----|-----|------|-----|
| R     | ACTIVE | DONE |    |    |    |    |    |    |    |    |    |    |     |     |      |     |
| W     |        | W1C  |    |    |    |    |    |    | 0  |    |    |    |     |     |      |     |
| Reset | 0      | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0    | 0   |
| Bits  | 15     | 14   | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3   | 2   | 1    | 0   |
| R     |        |      |    |    |    |    |    |    |    |    |    |    | EBW | EEI | EARQ | ERQ |
| W     |        |      |    |    | 0  |    |    |    |    |    |    |    | 0   | 0   | 0    | 0   |
| Reset | 0      | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0    | 0   |

**Fields**

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>ACTIVE | <p>Channel Active</p> <p>The ACTIVE field indicates the channel was selected by arbitration and is executing the prescribed transfers. The eDMA sets it to 1 when channel service begins, and clears it to 0 as the minor loop completes or when any error condition is detected. Except for dynamic scatter/gather or dynamic channel linking, you must not modify the transfer control descriptor when a channel is active.</p>             |
| 30<br>DONE   | <p>Channel Done</p> <p>The DONE field indicates the eDMA has completed the major loop. The eDMA engine sets this field as the CITER count reaches zero. If enabled, the eDMA generates an interrupt request corresponding to this completed channel. The software clears it, or the hardware clears it when the channel is activated.</p> <p><b>NOTE</b><br/>This field must be cleared to 0 before writing the MAJORELINK or ESG fields.</p> |
| 29-4<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3<br>EBW     | <p>Enable Buffered Writes</p> <p>When buffered writes are enabled, all writes except for the last write sequence of the minor loop are signaled by the eDMA as bufferable.</p> <p>0b - Buffered writes on system bus disabled. Buffered writes on system bus disabled</p> <p>1b - Buffered writes on system bus enabled. Bufferable write signal asserted on all system bus writes except during last write sequence</p>                      |
| 2<br>EEI     | <p>Enable Error Interrupt</p> <p>The EEI field enables the error interrupt signal for the channel. The DMA error indicator and the error interrupt enable flag must be asserted before an error interrupt request for a given channel is asserted to the interrupt controller.</p> <p>0b - Error signal for corresponding channel does not generate error interrupt</p>                                                                       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | 1b - Assertion of error signal for corresponding channel generates error interrupt request                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1<br>EARQ | <p>Enable Asynchronous DMA Request</p> <p>The enable asynchronous DMA request field (EARQ) does not affect DMA operations. When set to 1, this field allows the hardware service request enable field (ERQ) to propagate out of the DMA to the power controller. When cleared to 0, this field masks the hardware service request enable field to the power controller.</p> <p>0b - Disable asynchronous DMA request for the channel<br/>1b - Enable asynchronous DMA request for the channel</p>                                                                                                                                                         |
| 0<br>ERQ  | <p>Enable DMA Request</p> <p>Disable a channel's hardware service request at the source before clearing the channel's ERQ field. The DMA hardware request input signal and the enable request field (ERQ) must be asserted before a channel's hardware service request is accepted. The state of the eDMA enable request field does not affect a channel service request made explicitly through software or channel linking. The state of the ERQ field does not affect the channel's START field.</p> <p>0b - DMA hardware request signal for corresponding channel disabled<br/>1b - DMA hardware request signal for corresponding channel enabled</p> |

### 15.6.2.3 Channel Error Status (CH0\_ES - CH3\_ES)

#### Offset

| Register | Offset |
|----------|--------|
| CH0_ES   | 4h     |
| CH1_ES   | 1004h  |
| CH2_ES   | 2004h  |
| CH3_ES   | 3004h  |

#### Function

The ES provides information concerning the last recorded channel error. Channel errors can be caused by:

- An illegal setting in the transfer control descriptor
- An error termination to a bus master read or write cycle

The ERR field signals the presence of an error for the channel. The eDMA engine signals the occurrence of an error condition by setting the appropriate field in this register. The outputs of this register are enabled by the contents of the [CHn\\_CSR\[EEI\]](#) field, then logically summed across all channels to form an error interrupt request, which may be routed to the interrupt controller. In addition, this enabled error status is logically OR'd onto the channel done interrupt, [CHn\\_INT\[INT\]](#), thus forming a done or error interrupt on a per channel basis.

During the execution of the interrupt service routine associated with any DMA errors, it is software's responsibility to clear the appropriate bit, negating the error-interrupt request. The normal DMA channel completion indicators (setting the transfer control descriptor DONE flag and the possible assertion of an interrupt request) are not affected when eDMA detects an error. The

contents of this ERR register field can also be polled because a non-zero value indicates the presence of a channel error, regardless of the state of the EEI mask.

The state of any given channel's error indicators is affected by writes to this register. Writing a 1 to the ERR field clears the channel's error status, and writing a 0 has no effect.

An unspecified error, where only the ERR field is set to 1, indicates that either a transfer was cancelled with an error. The Management Page Error Status register has full view of the error condition.

See [Fault reporting and handling](#) for more details.

### Diagram

| Bits  | 31       | 30       | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16  |
|-------|----------|----------|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|
| R     | ERR      | Reserved |    |    |    |    |    |    |     |     |     |     |     |     |     |     |
| W     | W1C      | 0        |    |    |    |    |    |    |     |     |     |     |     |     |     |     |
| Reset | 0        | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Bits  | 15       | 14       | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| R     | Reserved |          |    |    |    |    |    |    | SAE | SOE | DAE | DOE | NCE | SGE | SBE | DBE |
| W     | 0        |          |    |    |    |    |    |    |     |     |     |     |     |     |     |     |
| Reset | 0        | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

### Fields

| Field     | Function                                                                                                                                                                                                               |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>ERR | Error In Channel<br><br>0b - An error in this channel has not occurred<br>1b - An error in this channel has occurred                                                                                                   |
| 30-8<br>— | Reserved                                                                                                                                                                                                               |
| 7<br>SAE  | Source Address Error<br><br>TCDn_SADDR is inconsistent with TCDn_ATTR[SSIZE].<br><br>0b - No source address configuration error<br>1b - Last recorded error was a configuration error detected in the TCDn_SADDR field |
| 6<br>SOE  | Source Offset Error<br><br>TCDn_SOFF is inconsistent with TCDn_ATTR[SSIZE].<br><br>0b - No source offset configuration error<br>1b - Last recorded error was a configuration error detected in the TCDn_SOFF field     |
| 5<br>DAE  | Destination Address Error<br><br>TCDn_DADDR is inconsistent with TCDn_ATTR[DSIZE].                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 0b - No destination address configuration error<br>1b - Last recorded error was a configuration error detected in the TCDn_DADDR field                                                                                                                                                                                                                                                                                                                                                      |
| 4<br>DOE | Destination Offset Error<br>TCDn_DOFF is inconsistent with TCDn_ATTR[DSIZE].<br>0b - No destination offset configuration error<br>1b - Last recorded error was a configuration error detected in the TCDn_DOFF field                                                                                                                                                                                                                                                                        |
| 3<br>NCE | NBYTES/CITER Configuration Error<br>This error indicates that one of the following has occurred:<br><ul style="list-style-type: none"> <li>• TCDn_NBYTES is not a multiple of TCDn_ATTR[SSIZE] and TCDn_ATTR[DSIZE]</li> <li>• TCDn_CITER[CITER] is equal to zero</li> <li>• TCDn_CITER[ELINK] is not equal to TCDn_BITER[ELINK]</li> </ul> 0b - No NBYTES/CITER configuration error<br>1b - Last recorded error was a configuration error detected in the TCDn_NBYTES or TCDn_CITER fields |
| 2<br>SGE | Scatter/Gather Configuration Error<br>When this field is 1, it indicates that <a href="#">TCDn_DLAST_SGA</a> is not on a 32-byte boundary. This field is checked at the beginning of a scatter/gather operation after major loop completion if <a href="#">TCDn_CSR[ESG]</a> is enabled.<br>0b - No scatter/gather configuration error<br>1b - Last recorded error was a configuration error detected in the TCDn_DLAST_SGA field                                                           |
| 1<br>SBE | Source Bus Error<br>0b - No source bus error<br>1b - Last recorded error was bus error on source read                                                                                                                                                                                                                                                                                                                                                                                       |
| 0<br>DBE | Destination Bus Error<br>0b - No destination bus error<br>1b - Last recorded error was bus error on destination write                                                                                                                                                                                                                                                                                                                                                                       |

#### 15.6.2.4 Channel Interrupt Status (CH0\_INT - CH3\_INT)

##### Offset

| Register | Offset |
|----------|--------|
| CH0_INT  | 8h     |
| CH1_INT  | 1008h  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Register | Offset |
|----------|--------|
| CH2_INT  | 2008h  |
| CH3_INT  | 3008h  |

### Function

The INT field signals the presence of an interrupt request for the channel. Depending on the appropriate bit setting in the transfer control descriptors, the eDMA engine generates an interrupt on data transfer completion or an error condition.

The outputs of this register are directly routed to the interrupt controller. During the interrupt service routine associated with any given channel, it is the software's responsibility to clear the appropriate bit, negating the interrupt request. On writes to INT, a 1 clears the channel's interrupt request. A zero has no effect on the channel's current interrupt status.

### Diagram

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

### Fields

| Field     | Function                                                                                                                                 |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31-1<br>— | Reserved                                                                                                                                 |
| 0<br>INT  | Interrupt Request<br>0b - Interrupt request for corresponding channel cleared<br>1b - Interrupt request for corresponding channel active |

### 15.6.2.5 Channel System Bus (CH0\_SBR - CH3\_SBR)

#### Offset

| Register | Offset |
|----------|--------|
| CH0_SBR  | Ch     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Register | Offset |
|----------|--------|
| CH1_SBR  | 100Ch  |
| CH2_SBR  | 200Ch  |
| CH3_SBR  | 300Ch  |

## Function

The Channel System Bus register places identification and attribute information on the system bus interface for the eDMA.

## Diagram

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

## Fields

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-17<br>— | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 16<br>EMI  | <p>Enable Master ID Replication</p> <p>The eDMA master ID replication field allows the eDMA to use the same protection level and system bus ID of the master programming the eDMA's TCD. When enabled, the eDMA uses the master ID and protection level stored in the <a href="#">CHn_SBR</a> registers, instead of the eDMA's default values. When a master (for example a core) programs a TCD, its master ID is captured when the TCD<math>n</math>_CSR control attributes are written. A scatter/gather operation does not affect the <a href="#">CHn_SBR</a> registers. You can write the EMI only if <a href="#">MP_CSR[GMRC]</a> = 1, which means Global Master ID Replication Control is enabled; otherwise, the EMI is forced to zero.</p> <p><b>NOTE</b></p> <p>If master ID replication is disabled, the nonsecure, user protection level for DMA transfers is used.</p> <p>0b - Master ID replication is disabled<br/>1b - Master ID replication is enabled</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>PAL  | <p>Privileged Access Level</p> <p>This field controls DMA's protection level on the system bus when the channel is active.</p> <p><b>NOTE</b></p> <p>When you enable master ID replication, the value captured in this register is the privilege level of the core or other master writing the channel's transfer control descriptor, which is the lower byte of TCD<math>n</math>_CSR.</p> <p>0b - User protection level for DMA transfers<br/>1b - Privileged protection level for DMA transfers</p> |
| 14-4<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 3-0<br>MID | <p>Master ID</p> <p>This field controls the DMA's master ID on the system bus when the channel is active.</p> <p><b>NOTE</b></p> <p>The ID captured in this register reflects the master ID of the core or other master writing the channel's control attributes, which are in the lower byte of TCD<math>n</math>_CSR.</p>                                                                                                                                                                            |

### 15.6.2.6 Channel Priority (CH0\_PRI - CH3\_PRI)

#### Offset

| Register | Offset |
|----------|--------|
| CH0_PRI  | 10h    |
| CH1_PRI  | 1010h  |
| CH2_PRI  | 2010h  |
| CH3_PRI  | 3010h  |

#### Function

The contents of these registers define unique priorities associated with each channel within the same channel group. Channel grouping is programmed via [Channel Arbitration Group \(CH0\\_GRPRI - CH3\\_GRPRI\)](#).

The channel priorities within a group are evaluated by numeric value; for example, 0 is the lowest priority, 1 is the next higher priority, then 2, 3, and so on. Software must program the channel priorities with unique values; otherwise, channel numbers with the same, non-zero value, will be selected based on channel number with the higher channel number having higher priority.

If more than one channel in a group has an arbitration priority level value of zero, then the arbitration mode field [MP\\_CSR\[ERCA\]](#) is used to determine the arbitration scheme for all channels with APL=0 within a group.

When you enable round-robin channel arbitration ([MP\\_CSR\[ERCA\]](#) = 1), all channels with APL=0 within a group will use a round-robin arbitration scheme, which rotates among these channels requesting service without regard to priority. Round-robin provides a fairness mechanism within an arbitration group.

When you enable fixed-priority channel arbitration ([MP\\_CSR\[ERCA\]](#) = 0), eDMA selects channels with APL=0 based on channel number, with the higher channel number having higher priority.

### Diagram

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

### Fields

| Field      | Function                                                                                                                                                                                                 |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>ECP  | Enable Channel Preemption<br>0b - Channel cannot be suspended by a higher-priority channel's service request<br>1b - Channel can be temporarily suspended by a higher-priority channel's service request |
| 30<br>DPA  | Disable Preempt Ability<br>0b - Channel can suspend a lower-priority channel<br>1b - Channel cannot suspend any other channel, regardless of channel priority                                            |
| 29-3<br>—  | Reserved                                                                                                                                                                                                 |
| 2-0<br>APL | Arbitration Priority Level<br>Channel priority level for arbitration within the assigned arbitration group.                                                                                              |

### 15.6.2.7 Channel Multiplexor Configuration (CH0\_MUX - CH3\_MUX)

#### Offset

| Register | Offset |
|----------|--------|
| CH0_MUX  | 14h    |
| CH1_MUX  | 1014h  |
| CH2_MUX  | 2014h  |
| CH3_MUX  | 3014h  |

## Function

Each of the DMA channels can be independently associated with various peripherals in the system. The Channel Multiplexor Configuration register selects the peripheral assigned to each channel. Service requests from the peripheral should be disabled when configuring a channel to a peripheral source.

Each channel must have a unique value when selecting a peripheral slot in the channel mux configuration. The only value that may overlap is source 0. If there is an attempt to write a mux configuration value that is already consumed by any channel, a mux configuration of 0 (SRC = 0) will be written.

All channels will default to source 0. When a particular peripheral is needed, the channel's mux configuration is set to that source number. When the peripheral is no longer needed, the mux configuration for that channel should be written to 0, thus releasing the resource.

## Diagram

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

## Fields

| Field      | Function                                                                                                                                                                                |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-7<br>—  | Reserved                                                                                                                                                                                |
| 6-0<br>SRC | Service Request Source<br>Hardware service request source for the channel.<br><br><b>NOTE</b><br>With the exception of 0, attempts to write a value already in use will be forced to 0. |

## 15.6.2.8 TCD Source Address (TCD0\_SADDR - TCD3\_SADDR)

### Offset

| Register   | Offset |
|------------|--------|
| TCD0_SADDR | 20h    |
| TCD1_SADDR | 1020h  |
| TCD2_SADDR | 2020h  |

Table continues on the next page...

*Table continued from the previous page...*

| Register   | Offset |
|------------|--------|
| TCD3_SADDR | 3020h  |

### Function

This register contains the address for the read transactions.

### Diagram

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

### Fields

| Field | Function                                    |
|-------|---------------------------------------------|
| 31-0  | Source Address                              |
| SADDR | Memory address pointing to the source data. |

### 15.6.2.9 TCD Signed Source Address Offset (TCD0\_SOFF - TCD3\_SOFF)

#### Offset

| Register  | Offset |
|-----------|--------|
| TCD0_SOFF | 24h    |
| TCD1_SOFF | 1024h  |
| TCD2_SOFF | 2024h  |
| TCD3_SOFF | 3024h  |

#### Function

This register contains the sign-extended value added to Source Address register after each read transaction.

**Diagram****Fields**

| Field | Function                                                                                                                  |
|-------|---------------------------------------------------------------------------------------------------------------------------|
| 15-0  | Source Address Signed Offset                                                                                              |
| SOFF  | Sign-extended offset applied to the current source address to form the next-state value as each source read is completed. |

**15.6.2.10 TCD Transfer Attributes (TCD0\_ATTR - TCD3\_ATTR)****Offset**

| Register  | Offset |
|-----------|--------|
| TCD0_ATTR | 26h    |
| TCD1_ATTR | 1026h  |
| TCD2_ATTR | 2026h  |
| TCD3_ATTR | 3026h  |

**Function**

This register contains size and option modulo addressing information for source and destination addresses.

**Diagram****Fields**

| Field | Function                                                                                                                                                                                                             |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-11 | Source Address Modulo                                                                                                                                                                                                |
| SMOD  | This field defines a specific address range, which is the value after the SADDR + SOFF calculation is performed on the original register value. Setting this field makes it easy to implement a circular data queue. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | <p>For data queues requiring power-of-2-sized bytes, the queue must start at a 0-modulo-size address and the SMOD field must be set to the appropriate value for the queue, freezing the required number of upper address bits.</p> <p>The value programmed into this field specifies the number of lower address bits that are allowed to change. For a circular queue application, you typically set TCDn_SOFF[SOFF] to the transfer size to implement post-increment addressing, with the SMOD function constraining the addresses to a 0-modulo-size range.</p> <ul style="list-style-type: none"> <li>0_0000b - Source address modulo feature disabled</li> <li>0_0001b - Source address modulo feature enabled for any non-zero value [1-31]</li> </ul> |
| 10-8<br>SSIZE | <p>Source Data Transfer Size</p> <ul style="list-style-type: none"> <li>000b - 8-bit</li> <li>001b - 16-bit</li> <li>010b - 32-bit</li> <li>011b - 64-bit</li> <li>100b - 16-byte</li> <li>101b - 32-byte</li> <li>110b - Reserved</li> <li>111b - Reserved</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 7-3<br>DMOD   | Destination Address Modulo<br>See the SMOD definition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 2-0<br>DSIZE  | Destination Data Transfer Size<br>See the SSIZE definition.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

#### 15.6.2.11 TCD Transfer Size Without Minor Loop Offsets (TCD0\_NBYTES\_MloffNO - TCD3\_NBYTES\_MloffNO)

##### Offset

| Register            | Offset |
|---------------------|--------|
| TCD0_NBYTES_MloffNO | 28h    |
| TCD1_NBYTES_MloffNO | 1028h  |
| TCD2_NBYTES_MloffNO | 2028h  |
| TCD3_NBYTES_MloffNO | 3028h  |

## Function

The TCDn\_NBYTES field defines the number of bytes to transfer per service request.

Minor loop offsets are address offset values added to the final source address (TCDn\_SADDR), or destination address (TCDn\_DADDR), upon minor loop completion. Minor loop completion is when the channel has finished the service request and has transferred NBYTES. When minor loop offsets are enabled, the minor loop offset value (TCDn\_NBYTES\_MLOFFYES[MLOFF]) is added to the final source address (TCDn\_SADDR), to the final destination address (TCDn\_DADDR), or to both, prior to the addresses being written back to the TCD. If the major loop is complete, the minor loop offset is ignored and the major loop address offsets (TCDn\_SLAST\_SDA and TCDn\_DLST\_SGA) are used to compute the next TCDn\_SADDR and TCDn\_DADDR values.

When minor loop mapping is enabled (SMLOE or DMLOE is 1), TCDn\_NBYTES\_MLOFFNO/TCDn\_NBYTES\_MLOFFYES is redefined. A portion of TCDn\_NBYTES\_MLOFFNO/TCDn\_NBYTES\_MLOFFYES is used to specify multiple fields:

- A source enable bit (SMLOE) to specify the minor loop offset must be applied to the source address (TCDn\_SADDR) upon minor loop completion
- A destination enable bit (DMLOE) to specify the minor loop offset must be applied to the destination address (TCDn\_DADDR) upon minor loop completion
- The sign extended minor loop offset value (MLOFF)

The same offset value (MLOFF) is used for both source and destination minor loop offsets. When either minor loop offset is enabled (SMLOE set or DMLOE set), the NBYTES field is reduced to 10 bits. If both minor loop offsets are disabled (SMLOE cleared and DMLOE cleared), the NBYTES field is a 30-bit vector.

One of two register profiles (this register or TCDn\_NBYTES\_MLOFFYES), defines the number of bytes to transfer per request. Which register to use depends on whether source or destination minor loop mapping is enabled.

TCDn\_NBYTES\_MLOFFNO/TCDn\_NBYTES\_MLOFFYES is defined as follows:

- If SMLOE = 0 and DMLOE = 0, then see the TCDn\_NBYTES\_MLOFFNO register description.
- If either SMLOE or DMLOE is 1, then see the TCDn\_NBYTES\_MLOFFYES register description.

## Diagram

| Bits  | 31   | 30   | 29 | 28 | 27 | 26 | 25 | 24 | 23     | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------|------|----|----|----|----|----|----|--------|----|----|----|----|----|----|----|
| R     | SMLO | DMLO |    |    |    |    |    |    |        |    |    |    |    |    |    |    |
| W     | E    | E    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |
|       |      |      |    |    |    |    |    |    |        |    |    |    |    |    |    |    |
| Reset | u    | u    | u  | u  | u  | u  | u  | u  | u      | u  | u  | u  | u  | u  | u  | u  |
| Bits  | 15   | 14   | 13 | 12 | 11 | 10 | 9  | 8  | 7      | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     |      |      |    |    |    |    |    |    | NBYTES |    |    |    |    |    |    |    |
| W     |      |      |    |    |    |    |    |    |        |    |    |    |    |    |    |    |
| Reset | u    | u    | u  | u  | u  | u  | u  | u  | u      | u  | u  | u  | u  | u  | u  | u  |

## Fields

| Field | Function                                                                                           |
|-------|----------------------------------------------------------------------------------------------------|
| 31    | Source Minor Loop Offset Enable                                                                    |
| SMLOE | Selects whether the minor loop offset is applied to the source address upon minor loop completion. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | 0b - Minor loop offset not applied to SADDR<br>1b - Minor loop offset applied to SADDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 30<br>DMLOE    | Destination Minor Loop Offset Enable<br>Selects whether the minor loop offset is applied to the destination address upon minor loop completion.<br>0b - Minor loop offset not applied to DADDR<br>1b - Minor loop offset applied to DADDR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 29-0<br>NBYTES | Number of Bytes To Transfer Per Service Request<br>Number of bytes to be transferred for each service request of the channel.<br>When a channel activates, the module loads the appropriate TCD contents into the eDMA engine and performs the appropriate reads and writes until the byte transfer count has been reached. This process is normally an indivisible operation and cannot be halted. It can, however, be stalled by using the bandwidth control field, or via preemption.<br>After the byte count is exhausted, the SADDR and DADDR values are written back into the TCD memory, and the major loop iteration count (CITER) is decremented by one and written back to the TCD memory. If the major iteration count is complete, additional processing is performed. |

#### 15.6.2.12 TCD Transfer Size with Minor Loop Offsets (TCD0\_NBYTES\_MloffYES - TCD3\_NBYTES\_MloffYES)

##### Offset

| Register             | Offset |
|----------------------|--------|
| TCD0_NBYTES_MloffYES | 28h    |
| TCD1_NBYTES_MloffYES | 1028h  |
| TCD2_NBYTES_MloffYES | 2028h  |
| TCD3_NBYTES_MloffYES | 3028h  |

##### Function

The TCDn\_NBYTES field defines the number of bytes to transfer per service request.

Minor loop offset is an address offset value added to the final source address (TCDn\_SADDR) or destination address (TCDn\_DADDR) upon minor loop completion. Minor loop completion occurs when the channel has finished the service request and has transferred NBYTES. Minor loop offsets are enabled by setting either the source enable bit (SMLOE) or the destination enable bit (DMLOE).

The source enable bit (SMLOE) specifies the minor loop offset value (Mloff) that is to be applied to the source address (TCDn\_SADDR) upon minor loop completion. The destination enable bit (DMLOE) specifies the minor loop offset (Mloff) that is to be applied to the destination address (TCDn\_DADDR) upon minor loop completion.

If the major loop is complete, the minor loop offsets are ignored and the major loop address offsets (TCDn\_SLAST\_SDA and TCDn\_DLAST\_SGA) are used to compute the next TCDn\_SADDR and TCDn\_DADDR values.

When you enable the minor loop offset overlay (either SMLOE or DMLOE is 1), eDMA redefines [TCDn\\_NBYTES\\_MloffNO](#)/[TCDn\\_NBYTES\\_MloffYES](#). A portion of TCDn\_NBYTES\_MloffNO/TCDn\_NBYTES\_MloffYES specifies the sign-extended minor loop offset value (Mloff). The same offset value (Mloff) applies to both source and destination minor loop offsets. When the minor loop offset is enabled, you must align it to the transfer size of the source or destination it is associated with. When either minor loop offset is enabled (SMLOE set or DMLOE set), the NBYTES field is reduced to 10 bits. If both minor loop offsets are disabled (SMLOE cleared and DMLOE cleared), the NBYTES field is a 30-bit vector.

One of two register profiles (this register or TCDn\_NBYTES\_MloffNO) defines the number of bytes to transfer per request. Which register to use depends on whether source or destination minor loop mapping is enabled.

TCDn\_NBYTES\_MloffYES is defined as follows:

- If either minor loop offset is enabled (SMLOE or DMLOE = 1), then see the TCDn\_NBYTES\_MloffYES register description.
- If SMLOE and DMLOE are both 0, then see the TCDn\_NBYTES\_MloffNO register description.

#### Diagram

| Bits  | 31    | 30    | 29 | 28 | 27    | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19     | 18 | 17 | 16 |
|-------|-------|-------|----|----|-------|----|----|----|----|----|----|----|--------|----|----|----|
| R     | SMLOE | DMLOE |    |    |       |    |    |    |    |    |    |    |        |    |    |    |
| W     | E     | E     |    |    |       |    |    |    |    |    |    |    |        |    |    |    |
|       |       |       |    |    |       |    |    |    |    |    |    |    |        |    |    |    |
| Reset | u     | u     | u  | u  | u     | u  | u  | u  | u  | u  | u  | u  | u      | u  | u  | u  |
| Bits  | 15    | 14    | 13 | 12 | 11    | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3      | 2  | 1  | 0  |
| R     |       |       |    |    | Mloff |    |    |    |    |    |    |    | Nbytes |    |    |    |
| W     |       |       |    |    |       |    |    |    |    |    |    |    |        |    |    |    |
| Reset | u     | u     | u  | u  | u     | u  | u  | u  | u  | u  | u  | u  | u      | u  | u  | u  |

#### Fields

| Field       | Function                                                                                                                                                                                                                                  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>SMLOE | Source Minor Loop Offset Enable<br>Selects whether the minor loop offset is applied to the source address upon minor loop completion.<br>0b - Minor loop offset not applied to SADDR<br>1b - Minor loop offset applied to SADDR           |
| 30<br>DMLOE | Destination Minor Loop Offset Enable<br>Selects whether the minor loop offset is applied to the destination address upon minor loop completion.<br>0b - Minor loop offset not applied to DADDR<br>1b - Minor loop offset applied to DADDR |
| 29-10       | Minor Loop Offset                                                                                                                                                                                                                         |

Table continues on the next page...

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Mloff         | If SMLOE or DMLOE is 1, this field represents a sign-extended offset applied to the source or destination address to form the next-state value after the minor loop completes.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 9-0<br>NBYTES | <p>Number of Bytes To Transfer Per Service Request</p> <p>The number of bytes to be transferred in each service request of the channel.</p> <p>As a channel activates, the module loads the appropriate TCD contents into the eDMA engine and performs the appropriate reads and writes until the minor byte transfer count has been reached. This is an indivisible operation and cannot be halted. It can, however, be stalled by using the bandwidth control field, or via preemption.</p> <p>After the minor count is exhausted, the SADDR and DADDR values are written back into the TCD memory, and the major iteration count is decremented and restored to the TCD memory. If the major iteration count is complete, additional processing is performed.</p> |

### 15.6.2.13 TCD Last Source Address Adjustment / Store DADDR Address (TCD0\_SLAST\_SDA - TCD3\_SLAST\_SDA)

#### Offset

| Register       | Offset |
|----------------|--------|
| TCD0_SLAST_SDA | 2Ch    |
| TCD1_SLAST_SDA | 102Ch  |
| TCD2_SLAST_SDA | 202Ch  |
| TCD3_SLAST_SDA | 302Ch  |

#### Function

This register contains the value added to the source address when the major loop is complete. When the store destination address option is enabled, this field provides a pointer to memory for storing the final destination address.

#### Diagram



**Fields**

| Field             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>SLAST_SDA | <p>Last Source Address Adjustment / Store DADDR Address</p> <p>Source last address adjustment or the system memory address for destination address (DADDR) storage.</p> <p>If (TCDn_CSR[ESDA] = 0), then:</p> <ul style="list-style-type: none"> <li>• Adjustment value is added to the source address at the completion of the major iteration count. This value can be used to restore the source address to the initial value or adjust the address to reference the next data structure.</li> <li>• This field uses two's complement notation for the final source address adjustment.</li> </ul> <p>Otherwise:</p> <ul style="list-style-type: none"> <li>• This address points to the 32-bit-aligned memory location where the destination address (DADDR) is to be stored in system memory. By saving the final destination address in system memory via the ESDA feature, you are able to compute the size of a variable destination data buffer by simply subtracting the beginning DADDR from the final, saved DADDR. This feature is used together with the scatter/gather operation to prevent the loss of the final DADDR, which is overwritten during the scatter/gather operation.</li> </ul> <p>The "Store Destination Address" (SDA) value must be a 32-bit-aligned location because the eDMA forces the lower two address bits of the SLAST_SDA field to zero when ESDA is enabled. The module performs this write operation when the major loop is done; that is, when the major iteration count (CITER) decrements to zero.</p> |

**15.6.2.14 TCD Destination Address (TCD0\_DADDR - TCD3\_DADDR)****Offset**

| Register   | Offset |
|------------|--------|
| TCD0_DADDR | 30h    |
| TCD1_DADDR | 1030h  |
| TCD2_DADDR | 2030h  |
| TCD3_DADDR | 3030h  |

**Function**

This register contains the address for the write transactions.

**Diagram**

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

**Fields**

| Field | Function                                         |
|-------|--------------------------------------------------|
| 31-0  | Destination Address                              |
| DADDR | Memory address pointing to the destination data. |

**15.6.2.15 TCD Signed Destination Address Offset (TCD0\_DOFF - TCD3\_DOFF)****Offset**

| Register  | Offset |
|-----------|--------|
| TCD0_DOFF | 34h    |
| TCD1_DOFF | 1034h  |
| TCD2_DOFF | 2034h  |
| TCD3_DOFF | 3034h  |

**Function**

This register contains the sign-extended value added to Destination Address register after each write transaction.

**Diagram****Fields**

| Field | Function                                                                                                                                     |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0  | Destination Address Signed Offset                                                                                                            |
| DOFF  | Sign-extended offset that is applied to the current destination address to form the next-state value as each destination write is completed. |

**15.6.2.16 TCD Current Major Loop Count (Minor Loop Channel Linking Disabled) (TCD0\_CITER\_ELINKNO - TCD3\_CITER\_ELINKNO)****Offset**

| Register           | Offset |
|--------------------|--------|
| TCD0_CITER_ELINKNO | 36h    |
| TCD1_CITER_ELINKNO | 1036h  |
| TCD2_CITER_ELINKNO | 2036h  |
| TCD3_CITER_ELINKNO | 3036h  |

**Function**

If TCDn\_CITER[ELINK] is 0, the TCDn\_CITER register is defined as follows.

**Diagram****Fields**

| Field       | Function    |
|-------------|-------------|
| 15<br>ELINK | Enable Link |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | <p>As the channel completes the minor loop, this flag enables linking to another channel as defined by the relevant LINKCH field. The link target channel initiates a channel service request via an internal mechanism that sets the TCDn_CSR[START] bit of the specified channel to 1.</p> <p>If channel linking is disabled, the CITER value is extended to 15 bits in place of a link channel number. If the major loop is exhausted, this link mechanism is suppressed in favor of MAJORELINK channel linking.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field must be equal to the BITER[ELINK] field; otherwise, a configuration error is reported.</p> <hr/> <p>0b - Channel-to-channel linking disabled</p> <p>1b - Channel-to-channel linking enabled</p>                                                                                                                                                                      |
| 14-0<br>CITER | <p>Current Major Iteration Count</p> <p>This 9-bit (ELINK = 1) or 15-bit (ELINK = 0) count represents the current major loop count for the channel. It is decremented each time the channel finishes a service request and is written back to TCD memory. After the major iteration count is exhausted, the channel performs a number of operations — for example, final source and destination address calculations — and optionally generates an interrupt to signal channel completion before reloading the CITER field from the Beginning Iteration Count (BITER) field.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>When the CITER field is initially loaded by software, it must be set to the same value as that contained in the BITER field.</p> <hr/> <p style="text-align: center;"><b>NOTE</b></p> <p>If the channel is configured to execute a single service request, the initial values of BITER and CITER should be 0x0001.</p> |

### 15.6.2.17 TCD Current Major Loop Count (Minor Loop Channel Linking Enabled) (TCD0\_CITER\_ELINKYES - TCD3\_CITER\_ELINKYES)

#### Offset

| Register            | Offset |
|---------------------|--------|
| TCD0_CITER_ELINKYES | 36h    |
| TCD1_CITER_ELINKYES | 1036h  |
| TCD2_CITER_ELINKYES | 2036h  |
| TCD3_CITER_ELINKYES | 3036h  |

**Function**

If TCDn\_CITER[ELINK] is 1, the TCDn\_CITER register is defined as follows.

**Diagram****Fields**

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>ELINK    | <p>Enable Link</p> <p>As the channel completes the minor loop, this flag enables linking to another channel as defined by the relevant LINKCH field. When enabled, an internal mechanism sets the TCDn_CSR[START] field of the specified channel (LINKCH) upon minor loop completion.</p> <p>If channel linking is disabled, the CITER value is extended to 15 bits in place of a link channel number. If the major loop is exhausted, this link mechanism is suppressed in favor of MAJORELINK channel linking.</p> <p><b>NOTE</b><br/>This field must be equal to the BITER[ELINK] field; otherwise, a configuration error is reported.</p> <p>0b - Channel-to-channel linking disabled<br/>1b - Channel-to-channel linking enabled</p> |
| 14-11<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 10-9<br>LINKCH | <p>Minor Loop Link Channel Number</p> <p>If channel-to-channel linking is enabled (ELINK = 1), then after the minor loop is exhausted the eDMA engine initiates a channel service request to the channel defined by this field by writing that channel's TCDn_CSR[START] field to 1.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 8-0<br>CITER   | <p>Current Major Iteration Count</p> <p>This 9-bit (ELINK = 1) or 15-bit (ELINK = 0) count represents the current major loop count for the channel. It is decremented each time the channel finishes a service request and is written back to the TCD memory. After the major iteration count is exhausted, the channel performs a number of operations — for example, final source and destination address calculations — and optionally generates an interrupt to signal channel completion before reloading the CITER field from the Beginning Iteration Count (BITER) field.</p> <p><b>NOTE</b><br/>When the CITER field is initially loaded by software, it must be set to the same value as that contained in the BITER field.</p>  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                        |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <p style="text-align: center;"><b>NOTE</b></p> <p>If the channel is configured to execute a single service request, the initial values of BITER and CITER should be 0x0001.</p> |

### 15.6.2.18 TCD Last Destination Address Adjustment / Scatter Gather Address (TCD0\_DLAST\_SGA - TCD3\_DLAST\_SGA)

#### Offset

| Register       | Offset |
|----------------|--------|
| TCD0_DLAST_SGA | 38h    |
| TCD1_DLAST_SGA | 1038h  |
| TCD2_DLAST_SGA | 2038h  |
| TCD3_DLAST_SGA | 3038h  |

#### Function

This register contains the value added to the destination address when the major loop is complete. When the Scatter/Gather option is enabled, this field provides a pointer to memory for fetching a transfer control descriptor to reprogram the channel.

#### Diagram



#### Fields

| Field             | Function                                                                                                                                                                                                                                                   |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>DLAST_SGA | Last Destination Address Adjustment / Scatter Gather Address<br>Adjustment of the last destination address or the memory address for the next transfer control descriptor to be loaded into this channel (scatter/gather).<br>If (TCDn_CSR[ESG] = 0) then: |

*Table continues on the next page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <ul style="list-style-type: none"> <li>Adjustment value is added to the destination address at the completion of the major iteration count. This value can apply to restore the destination address to the initial value or adjust the address to reference the next data structure.</li> <li>This field uses two's complement notation for the final destination address adjustment.</li> </ul> <p>Otherwise:</p> <ul style="list-style-type: none"> <li>This address points to the beginning of a 0-modulo 32-byte region containing the next transfer control descriptor to be loaded into this channel. This channel reload is performed as the major iteration count completes. The scatter/gather address must be 0-modulo 32-byte, or else a configuration error is reported.</li> </ul> |

### 15.6.2.19 TCD Control and Status (TCD0\_CSR - TCD3\_CSR)

#### Offset

| Register | Offset |
|----------|--------|
| TCD0_CSR | 3Ch    |
| TCD1_CSR | 103Ch  |
| TCD2_CSR | 203Ch  |
| TCD3_CSR | 303Ch  |

#### Function

This register is used to enable optional features.

#### Diagram



#### Fields

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-14<br>BWC | <p>Bandwidth Control</p> <p>Throttles the amount of bus bandwidth consumed by the eDMA. Generally, as the eDMA processes the minor loop, it continuously generates read/write sequences until the minor count is exhausted. This field forces eDMA to stall after the completion of each read/write access, to control the bus request bandwidth seen by the system bus interconnect.</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field              | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | <p style="text-align: center;"><b>NOTE</b></p> <p>If the source and destination sizes are equal, this field is ignored between the first and second transfers and after the last write of each minor loop. This behavior is a side effect of reducing start-up latency.</p> <p>00b - No eDMA engine stalls<br/>     01b - Reserved<br/>     10b - eDMA engine stalls for 4 cycles after each R/W<br/>     11b - eDMA engine stalls for 8 cycles after each R/W</p>                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 13-10<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 9-8<br>MAJORLINKCH | <p>Major Loop Link Channel Number</p> <p>If (MAJORELINK = 0) then:</p> <ul style="list-style-type: none"> <li>No channel-to-channel linking, or chaining, is performed after the major loop counter is exhausted.</li> </ul> <p>Otherwise:</p> <ul style="list-style-type: none"> <li>After the major loop counter is exhausted, the eDMA engine initiates a channel service request at the channel defined by this field by setting that channel's TCDn_CSR[START] field to 1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                    |
| 7<br>ESDA          | <p>Enable Store Destination Address</p> <p>As the channel completes the major loop by either the current iteration counter (CITER) decrementing to 0, or by receiving an enabled end-of-packet signal, this field enables writing the destination address (DADDR) to the address stored in the SLAST_SDA field. The value written to system memory is the last DADDR value prior to the DLAST_SGA offset being applied, or overwritten by an enabled scatter/gather operation. When the ESDA bit is 1, SLAST_SDA contains the write pointer instead of the final source address offset. Because this is a pointer and not a final offset, a last source address offset of zero is applied to SADDR instead of the SLAST_SGA value.</p> <p>0b - Ability to store destination address to system memory disabled<br/>     1b - Ability to store destination address to system memory enabled</p> |
| 6<br>EEOP          | <p>Enable End-Of-Packet Processing</p> <p>When enabled by the EEOP field, an end-of-packet hardware input signal directs eDMA to discontinue executing the active channel, and to treat the shutdown as the major-loop-completed event. If the EEOP field is 1, the end-of-packet signal from supported peripherals is accepted. If the EEOP field is 0, the end-of-packet input is ignored. With an end-of-packet retirement, the current TCD destination address (or ESDA-saved destination address), minus the software-saved initial address (DADDR), reflects the total amount of data transferred.</p> <p>0b - End-of-packet operation disabled<br/>     1b - End-of-packet hardware input signal enabled</p>                                                                                                                                                                           |
| 5                  | Enable Link When Major Loop Complete                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAJORELINK    | <p>As the channel completes the major loop, this flag enables linking to another channel defined by MAJORLINKCH. The link target channel initiates a channel service request via an internal mechanism that sets the TCDn_CSR[START] field of the specified channel.</p> <p><b>NOTE</b><br/>To support the dynamic linking coherency model, this field is forced to 0 if written when TCDn_CSR[DONE] is 1.</p> <p>0b - Channel-to-channel linking disabled<br/>1b - Channel-to-channel linking enabled</p>                                                                                                                                                                                                                              |
| 4<br>ESG      | <p>Enable Scatter/Gather Processing</p> <p>As the channel completes the major loop, this flag enables scatter/gather processing in the current channel. If enabled, the eDMA engine uses <a href="#">TCDn_DLAST_SGA</a> as a memory pointer to a 0-modulo 32-bit address containing a 32-byte data structure, which is loaded as the transfer control descriptor into local memory.</p> <p><b>NOTE</b><br/>To support the dynamic scatter/gather coherency model, this field is forced to 0 if written when TCDn_CSR[DONE] is 1.</p> <p>0b - Current channel's TCD is normal format<br/>1b - Current channel's TCD specifies scatter/gather format.</p>                                                                                 |
| 3<br>DREQ     | <p>Disable Request</p> <p>If this flag is 1, the eDMA hardware automatically clears the corresponding ERQ bit when the current major iteration count reaches 0.</p> <p>0b - No operation. Channel's ERQ field not affected<br/>1b - Clear the ERQ field to 0 upon major loop completion, thus disabling hardware service requests. Channel's ERQ field cleared to 0 when major loop complete</p>                                                                                                                                                                                                                                                                                                                                        |
| 2<br>INTHALF  | <p>Enable Interrupt If Major Counter Half-complete</p> <p>If this flag is 1, the channel generates an interrupt request by setting the appropriate field in the INT register to 1 when the current major iteration count reaches the halfway point. Specifically, the comparison performed by the eDMA engine is (CITER = (BITER/2)). This halfway point interrupt request is provided to support double-buffered, also known as ping-pong, schemes, or other types of data movement where the processor needs an early indication of the transfer's progress.</p> <p><b>NOTE</b><br/>If BITER = 1, do not use INTHALF; use INTMAJOR instead.</p> <p>0b - Halfway point interrupt disabled<br/>1b - Halfway point interrupt enabled</p> |
| 1<br>INTMAJOR | <p>Enable Interrupt If Major count complete</p> <p>If this flag is 1, the channel generates an interrupt request by setting the appropriate field in the INT register to 1 when the current major iteration count (CITER) reaches 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                            |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | 0b - End-of-major loop interrupt disabled<br>1b - End-of-major loop interrupt enabled                                                                                                                                                                                               |
| 0<br>START | Channel Start<br>If this flag is 1, the channel is requesting service. The eDMA hardware automatically clears this flag to 0 after the channel begins execution.<br>0b - Channel not explicitly started<br>1b - Channel explicitly started via a software-initiated service request |

### 15.6.2.20 TCD Beginning Major Loop Count (Minor Loop Channel Linking Disabled) (TCD0\_BITER\_ELINKNO - TCD3\_BITER\_ELINKNO)

#### Offset

| Register           | Offset |
|--------------------|--------|
| TCD0_BITER_ELINKNO | 3Eh    |
| TCD1_BITER_ELINKNO | 103Eh  |
| TCD2_BITER_ELINKNO | 203Eh  |
| TCD3_BITER_ELINKNO | 303Eh  |

#### Function

If the TCDn\_BITER[ELINK] field is 0, the TCDn\_BITER register is defined as follows.

#### Diagram



#### Fields

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>ELINK | Enables Link<br>As the channel completes the minor loop, this flag enables linking to another channel as defined by BITER[LINKCH]. The link target channel initiates a channel service request via an internal mechanism that sets the TCDn_CSR[START] field of the specified channel. If channel linking is disabled, the BITER value extends to 15 bits in place of a link channel number. If the major loop is exhausted, this link mechanism is suppressed in favor of the MAJORELINK channel linking. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | <p style="text-align: center;"><b>NOTE</b></p> <p>When the software loads the TCD, this field must be set equal to the corresponding CITER field; otherwise, a configuration error is reported. As the major iteration count is exhausted, eDMA reloads the contents of this field into the CITER field.</p> <p style="margin-left: 40px;">0b - Channel-to-channel linking disabled<br/>1b - Channel-to-channel linking enabled</p>                 |
| 14-0<br>BITER | <p>Starting Major Iteration Count</p> <p>As the transfer control descriptor is first loaded by software, this 9-bit (ELINK = 1) or 15-bit (ELINK = 0) field must be set equal to the value in the CITER field. As the major iteration count is exhausted, eDMA reloads the contents of this field into the CITER field. If the channel is configured to execute a single service request, the initial values of BITER and CITER must be 0x0001.</p> |

### 15.6.2.21 TCD Beginning Major Loop Count (Minor Loop Channel Linking Enabled) (TCD0\_BITER\_ELINKYES - TCD3\_BITER\_ELINKYES)

#### Offset

| Register            | Offset |
|---------------------|--------|
| TCD0_BITER_ELINKYES | 3Eh    |
| TCD1_BITER_ELINKYES | 103Eh  |
| TCD2_BITER_ELINKYES | 203Eh  |
| TCD3_BITER_ELINKYES | 303Eh  |

#### Function

If the TCDn\_BITER[ELINK] field is set, the TCDn\_BITER register is defined as follows.

**Diagram****Fields**

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>ELINK    | <p>Enable Link</p> <p>As the channel completes the minor loop, this flag enables linking to another channel as defined by BITER[LINKCH]. The link target channel initiates a channel service request via an internal mechanism that sets the TCDn_CSR[START] field of the specified channel. If channel linking disables, the BITER value extends to 15 bits in place of a link channel number. If the major loop is exhausted, this link mechanism is suppressed in favor of the MAJORELINK channel linking.</p> <p><b>NOTE</b><br/>When the software loads the TCD, this field must be set equal to the corresponding CITER field; otherwise, a configuration error is reported. As the major iteration count is exhausted, eDMA reloads the contents of this field into the CITER field.</p> <p>0b - Channel-to-channel linking disabled<br/>1b - Channel-to-channel linking enabled</p> |
| 14-11<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 10-9<br>LINKCH | <p>Link Channel Number</p> <p>If channel-to-channel linking is enabled (ELINK = 1), then after the minor loop is exhausted, the eDMA engine initiates a channel service request at the channel defined by this field by setting that channel's TCDn_CSR[START] field.</p> <p><b>NOTE</b><br/>When the software loads the TCD, this field must be set equal to the corresponding CITER field; otherwise, a configuration error is reported. As the major iteration count is exhausted, eDMA reloads the contents of this field into the CITER field.</p>                                                                                                                                                                                                                                                                                                                                     |
| 8-0<br>BITER   | <p>Starting Major Iteration Count</p> <p>As the transfer control descriptor is first loaded by software, this 9-bit (ELINK = 1) or 15-bit (ELINK = 0) field must be set equal to the value in the CITER field. As the major iteration count is exhausted, eDMA reloads the contents of this field into the CITER field. If the channel is configured to execute a single service request, the initial values of BITER and CITER must be 0x0001.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                         |

# Chapter 16

## Wakeup Unit (WUU)

### 16.1 Chip-specific WUU information

Table 83. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | WUU            | <a href="#">WUU</a>                 |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 16.1.1 Module instances

This device contains one instance of the WUU module, WUU0.

#### 16.1.2 Clock signal names

LPO clock is clk\_16k[0].

#### 16.1.3 WUU sources

The device uses the following inputs as wakeup sources to the WUU module. The WUU\_Px inputs are connections to external physical pins. The WUU\_MxF inputs are connections to the internal peripheral interrupt flags from different modules that can operate in low-power modes. The WUU\_MxD inputs are connections to the internal peripheral Asynchronous DMA or module Triggers from different modules that can operate in low-power modes.

**NOTE**

In addition to the WUU wakeup sources, the device also wakes from low power modes when NMI or RESET pins are enabled and the respective pin is asserted.

Table 84. Wakeup Sources for WUU inputs

| WUU input | Source description |
|-----------|--------------------|
| WUU_P0    | Reserved           |
| WUU_P1    | Reserved           |
| WUU_P2    | P0_16              |
| WUU_P3    | Reserved           |
| WUU_P4    | Reserved           |
| WUU_P5    | Reserved           |
| WUU_P6    | P1_0 / LPTMR0_ALT3 |
| WUU_P7    | P1_3               |
| WUU_P8    | P1_4               |

*Table continues on the next page...*

**Table 84. Wakeup Sources for WUU inputs (continued)**

| WUU input | Source description |
|-----------|--------------------|
| WUU_P9    | P1_7               |
| WUU_P10   | P1_8               |
| WUU_P11   | P1_11              |
| WUU_P12   | P1_12              |
| WUU_P13   | Reserved           |
| WUU_P14   | Reserved           |
| WUU_P15   | Reserved           |
| WUU_P16   | Reserved           |
| WUU_P17   | Reserved           |
| WUU_P18   | P2_0               |
| WUU_P19   | P2_3               |
| WUU_P20   | P2_12              |
| WUU_P21   | Reserved           |
| WUU_P22   | P3_0               |
| WUU_P23   | P3_8               |
| WUU_P24   | P3_11              |
| WUU_P25   | P3_14              |
| WUU_P26   | P3_28              |
| WUU_P27   | P3_29              |
| WUU_P28   | USB0_DM            |
| WUU_P29   | USB0_DP            |
| WUU_P30   | Reserved           |
| WUU_P31   | CMP1_OUT           |
| WUU_M0IF  | SPC Interrupt      |
| WUU_M1IF  | Reserved           |
| WUU_M2IF  | Wake-up Timer      |
| WUU_M3IF  | Reserved           |
| WUU_M4IF  | Reserved           |
| WUU_M5IF  | Reserved           |
| WUU_M6IF  | LPTMR0 Interrupt   |
| WUU_M7IF  | Reserved           |
| WUU_M8IF  | CMP0 Interrupt     |

*Table continues on the next page...*

**Table 84. Wakeup Sources for WUU inputs (continued)**

| WUU input | Source description |
|-----------|--------------------|
| WUU_M9IF  | Reserved           |
| WUU_M0DR  | Reserved           |
| WUU_M1DR  | Reserved           |
| WUU_M2DR  | Reserved           |
| WUU_M3DR  | Reserved           |
| WUU_M4DR  | LPTMR0 DMA Request |
| WUU_M5DR  | Reserved           |
| WUU_M6DR  | LPTMR0 Trig        |
| WUU_M7DR  | Reserved           |
| WUU_M8DR  | CMP0 DMA Request   |
| WUU_M9DR  | Reserved           |

## 16.2 Overview

WUU facilitates in selecting external pins and on-chip modules as interrupt wake-up sources from Power Down/Deep Power Down power modes. You can also configure the external pins to act as interrupt wake-up sources in all power modes. WUU helps pins and modules generate a temporary wake-up from Power Down mode for servicing DMA or trigger events. Digital filtering is also available for the external wake-up pins.

See the chip-specific WUU information section for input sources to WUU.

### 16.2.1 Block diagram



Figure 24. WUU block diagram

### 16.2.2 Features

- Supports external input pins and on-chip modules with individual enable bits to wake the chip from low-leakage modes.
- Contains input sources that may be external pins or from on-chip modules capable of running in Power Down or Deep Power Down power modes. See the chip-specific WUU information for the wake-up input sources for this chip.
- Supports configuring on-chip modules as DMA or trigger sources for temporary wake-up from Power Down mode.
- Supports configuring external pins as DMA request or trigger sources for temporary wake-up from Power Down mode.
- Provides external input pins programmable for falling-edge, rising-edge, or any edge detection.
- Provides optional digital filters to qualify an external pin detect. Disabling the LPO clock bypasses and disables filters.
- Filters all external input pins; but only 2 filters are available at a given time.

- Enables external input pin and filter detection in all power modes (not limited to Power Down/Deep Power Down power modes).

## 16.3 Functional description

### 16.3.1 Operation

WUU allows on-chip modules and external input pins as a source of wake-up from low-leakage modes.

WUU contains pin enables for each external pin and on-chip module. For each external pin, you can disable or select the edge type for the wake-up with the following options:

- Falling edge
- Rising edge
- Either edge

Exit due to a pin event triggers a WUU interrupt after wake-up is complete. When enabling an external pin as a wake-up source, configure the pin as an input pin. You can also configure a pin to generate an interrupt from a Power Down/Deep Power Down mode or a DMA/trigger request for temporary wake-up from Power Down mode. Detection logic for a pin can optionally remain enabled during all power modes using [Pin Mode Configuration \(PMC\)](#).

On the basis of the LPO clock, WUU implements optional 3-cycle glitch filters. Detected external pin must remain asserted until the enabled glitch filter times out. Additional latency of up to two cycles is due to synchronization, which results in a total of up to five cycles of delay before the detect circuit alerts the system to the wake-up event when the filter function is enabled. Two wake-up detect filters are available for selected external pins. Glitch filtering is not provided for the on-chip modules. You can configure a filter to generate an interrupt from Power Down/Deep Power Down mode or a DMA/trigger request for temporary wake-up from Power Down mode. Detection logic for a filter can optionally remain enabled during all power modes using [Pin Filter Mode Configuration \(FMC\)](#).

For on-chip module interrupts, [ME\[WUME<sub>n</sub>\]](#) enables the associated module interrupt as a wake-up source. Exit due to a module interrupt will not trigger a WUU interrupt.

For on-chip module DMA/trigger requests, [DE\[WUDE<sub>n</sub>\]](#) enables the associated module DMA/trigger request as a wake-up source. Exit due to a module DMA/trigger request does not trigger a WUU interrupt.

### 16.3.2 Modes of operation

WUU becomes functional on entry into a low-leakage power mode. After recovery from Power Down mode, WUU is immediately disabled. After recovery from Deep Power Down mode, WUU continues to detect wake-up events until you have reinitialized the system and deasserted isolation. Detection of external pin/filter events can also optionally remain enabled in all power modes using [Pin Mode Configuration \(PMC\)/Pin Filter Mode Configuration \(FMC\)](#).

#### 16.3.2.1 Power Down mode

Wake-up events due to either an external pin input (WUU\_Px) or an on-chip module interrupt (WUU\_MxF) result in a CPU interrupt flow to begin user code execution. The source of the wake-up determines the subsequent path of code execution:

- Pin events trigger the WUU interrupt service routine.
- Module interrupts trigger that same module's interrupt service routine.

#### NOTE

The interrupt controller must not mask the WUU interrupt to avoid a scenario where the system does not fully recover from Power Down mode after an external pin event.

Wake-up events due to an on-chip module request (WUU\_MxDR) DMA/trigger request result in a temporary exit from Power Down mode to allow the request to be serviced when the CPU clock remains gated. The system reenters Power Down mode after servicing the request.

Wake-up events due to an external pin (WUU\_Px) DMA/trigger request result in a temporary exit from Power Down mode to allow the request to be serviced when the CPU clock remains gated. The system reenters Power Down mode after servicing the request.

### 16.3.2.2 Non-low-leakage modes

WUU is inactive in all non-low-leakage modes, with the exception of external pin/filter detection which can explicitly be kept enabled during all power modes using [Pin Mode Configuration \(PMC\)/Pin Filter Mode Configuration \(FMC\)](#). WUU chips are accessible in non-low-leakage modes and are available for configuring and reading status when bus transactions are possible.

### 16.3.3 Clocking

During chip low-power operation, in order to provide the wake-up function for the chip, ensure that clocking is available for WUU by the LPO clock. See the chip-specific WUU information for the chip clock connection details.

### 16.3.4 Reset

WUU resets after VSYS warm reset. This is the global chip reset, but it does not include the reset that asserts due to wake-up from low-power mode.

### 16.3.5 Interrupts

You can enable on-chip module interrupts as wake-up sources in [Module Interrupt Enable \(ME\)](#).

### 16.3.6 DMA

You can enable on-chip DMA requests as wake-up sources in [Module DMA/Trigger Enable \(DE\)](#).

With external pin inputs, you can generate a DMA request using either rising edge, falling edge, or both edge detection in [Pin DMA/Trigger Configuration 1 \(PDC1\)](#) and [Pin DMA/Trigger Configuration 2 \(PDC2\)](#).

## 16.4 External signals

Table 85. External signals

| Signal   | Description                                                                                         | I/O |
|----------|-----------------------------------------------------------------------------------------------------|-----|
| WUU_Pn   | External pin wake-up inputs; can be enabled to detect a rising edge, a falling edge, or any change. | I   |
| WUU_MnIF | On-chip module interrupt flags                                                                      | I   |
| WUU_MnDR | On-chip module DMA/trigger requests                                                                 | I   |

## 16.5 Initialization

For an enabled module wake-up input, clear the module's flag before entering Power Down or Deep Power Down mode to avoid an immediate exit from the mode.

Clear the flags associated with external input pins, filtered and unfiltered, prior to entry to Power Down or Deep Power Down mode.

When an external wake-up pin filter is first enabled in [Pin Filter \(FILT\)](#), filter operation begins immediately. After enabling an external pin filter or changing its source pin, wait for at least five LPO clock cycles to allow the filter to initialize before entering Power Down or Deep Power Down mode or before enabling filter detection for all power modes in [Pin Filter Mode Configuration \(FMC\)](#).

#### NOTE

After recovering from a Deep Power Down mode, you must restore the chip configuration before relaxing any power domain isolation controls. In particular, to avoid any WUU flag from being falsely set, restore the pin configuration for the enabled WUU wake-up pins before removing any voltage isolation between power domains.

## 16.6 Application information

To enable an external pin as a wake-up source in low-power modes, follow these steps:

1. If the flag is not 0, write 1 to [PF\[WUF \$n\$ \]](#).
2. Configure the PDC $m$ [WUPDC $n$ ] as either an interrupt or DMA request.
3. Configure the PE $m$ [WUPE $n$ ] for rising edge, falling edge, or both edge detection.

When you have configured an external pin to be an active wake-up source in all power modes ([PMC\[WUPMC \$n\$ \]](#) = 1), you must not change the corresponding wake-up pin enable (PE $m$ [WUPE $n$ ]) and wake-up pin configuration (PDC $m$ [WUPDC $n$ ]) settings for that pin. To modify the PE $m$ [WUPE $n$ ] or PDC $m$ [WUPDC $n$ ] settings, follow these steps:

1. Write 0 to [PMC\[WUPMC \$n\$ \]](#) for that pin.
2. Update the corresponding PE $m$ [WUPE $n$ ] or PDC $m$ [WUPDC $n$ ] settings as needed.
3. Write 1 to [PMC\[WUPMC \$n\$ \]](#) for that pin.

## 16.7 Memory map and register definition

This section includes the WUU module memory map and detailed descriptions of all registers.

### 16.7.1 WUU register descriptions

---

#### NOTE

You can write to WUU registers only in Supervisor mode. A bus error results from write accesses in User mode.

VSYS warm reset resets all WUU registers.

---

#### 16.7.1.1 WUU memory map

WUU0 base address: 4009\_2000h

| Offset | Register                                                   | Width<br>(In bits) | Access | Reset value |
|--------|------------------------------------------------------------|--------------------|--------|-------------|
| 0h     | <a href="#">Version ID (VERID)</a>                         | 32                 | R      | 0100_0001h  |
| 4h     | <a href="#">Parameter (PARAM)</a>                          | 32                 | R      | 2020_2002h  |
| 8h     | <a href="#">Pin Enable 1 (PE1)</a>                         | 32                 | RW     | 0000_0000h  |
| Ch     | <a href="#">Pin Enable 2 (PE2)</a>                         | 32                 | RW     | 0000_0000h  |
| 18h    | <a href="#">Module Interrupt Enable (ME)</a>               | 32                 | RW     | 0000_0000h  |
| 1Ch    | <a href="#">Module DMA/Trigger Enable (DE)</a>             | 32                 | RW     | 0000_0000h  |
| 20h    | <a href="#">Pin Flag (PF)</a>                              | 32                 | RW     | 0000_0000h  |
| 30h    | <a href="#">Pin Filter (FILT)</a>                          | 32                 | RW     | 0000_0000h  |
| 38h    | <a href="#">Pin DMA/Trigger Configuration 1 (PDC1)</a>     | 32                 | RW     | 0000_0000h  |
| 3Ch    | <a href="#">Pin DMA/Trigger Configuration 2 (PDC2)</a>     | 32                 | RW     | 0000_0000h  |
| 48h    | <a href="#">Pin Filter DMA/Trigger Configuration (FDC)</a> | 32                 | RW     | 0000_0000h  |
| 50h    | <a href="#">Pin Mode Configuration (PMC)</a>               | 32                 | RW     | 0000_0000h  |
| 58h    | <a href="#">Pin Filter Mode Configuration (FMC)</a>        | 32                 | RW     | 0000_0000h  |

### 16.7.1.2 Version ID (VERID)

#### Offset

| Register | Offset |
|----------|--------|
| VERID    | 0h     |

#### Function

Contains version numbers for the module design and feature set.

#### Diagram



#### Fields

| Field           | Function                                                                                                                                                                                                                                                                                                                                              |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24<br>MAJOR  | Major Version Number<br>Specifies the major version number for the module specification.                                                                                                                                                                                                                                                              |
| 23-16<br>MINOR  | Minor Version Number<br>Specifies the minor version number for the module specification.                                                                                                                                                                                                                                                              |
| 15-0<br>FEATURE | Feature Specification Number<br>Specifies the feature set number.<br><br>0000_0000_0000_0000b - Standard features implemented<br><br>0000_0000_0000_0001b - Support for DMA/Trigger generation from wake-up pins and filters enabled. Support for external pin/filter detection during all power modes enabled.<br><br>All other values are reserved. |

### 16.7.1.3 Parameter (PARAM)

#### Offset

| Register | Offset |
|----------|--------|
| PARAM    | 4h     |

#### Function

Contains parameter values implemented in the module.

#### Diagram



#### Fields

| Field            | Function                                                             |
|------------------|----------------------------------------------------------------------|
| 31-24<br>PINS    | Pin Number<br>Indicates the number of pin wake-up sources supported. |
| 23-16<br>MODULES | Module Number<br>Indicates the number of module wake-up sources.     |
| 15-8<br>DMAS     | DMA Number<br>Indicates the number of DMA wake-up sources.           |
| 7-0<br>FILTERS   | Filter Number<br>Indicates the number of pin filters.                |

### 16.7.1.4 Pin Enable 1 (PE1)

#### Offset

| Register | Offset |
|----------|--------|
| PE1      | 8h     |

**Function**

Enables and selects the edge detect type for the available external wake-up input pins in the range from WUU\_P0 to WUU\_P15.

**NOTE**

- Do not modify the value of PE1[WUPE $n$ ] when its corresponding PMC[WUPMC $n$ ] = 1.
- VSYS warm reset resets this register.

**Diagram**

| Bits  | 31    | 30    | 29 | 28 | 27 | 26 | 25     | 24     | 23     | 22    | 21    | 20 | 19 | 18 | 17 | 16 |
|-------|-------|-------|----|----|----|----|--------|--------|--------|-------|-------|----|----|----|----|----|
| R     | 0     | 0     | 0  | 0  | 0  | 0  | WUPE12 | WUPE11 | WUPE10 | WUPE9 | WUPE8 |    |    |    |    |    |
| Reset | 0     | 0     | 0  | 0  | 0  | 0  | 0      | 0      | 0      | 0     | 0     | 0  | 0  | 0  | 0  | 0  |
| Bits  | 15    | 14    | 13 | 12 | 11 | 10 | 9      | 8      | 7      | 6     | 5     | 4  | 3  | 2  | 1  | 0  |
| R     | WUPE7 | WUPE6 |    |    | 0  | 0  | 0      | 0      | 0      | 0     | 0     | 0  | 0  | 0  | 0  | 0  |
| Reset | 0     | 0     | 0  | 0  | 0  | 0  | 0      | 0      | 0      | 0     | 0     | 0  | 0  | 0  | 0  | 0  |

**Fields**

| Field               | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30<br>Reserved15 | <p>Reserved</p> <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> <p>00b - Not supported<br/>01b - Not supported<br/>10b - Not supported<br/>11b - Not supported</p> |
| 29-28<br>Reserved14 | <p>Reserved</p> <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> <p>00b - Not supported<br/>01b - Not supported</p>                                                 |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field               | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     | 10b - Not supported<br>11b - Not supported                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 27-26<br>Reserved13 | Reserved <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> 00b - Not supported<br>01b - Not supported<br>10b - Not supported<br>11b - Not supported                                                                                                                                                                                                |
| 25-24<br>WUPE12     | Wake-up Pin Enable for WUU_Pn<br>Enables the external input pin for wake-up. This field configures the edge detection as follows: <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> 00b - Disable<br>01b - Enable (detect on rising edge or high level)<br>10b - Enable (detect on falling edge or low level)<br>11b - Enable (detect on any edge) |
| 23-22<br>WUPE11     | Wake-up Pin Enable for WUU_Pn<br>Enables the external input pin for wake-up. This field configures the edge detection as follows: <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> 00b - Disable<br>01b - Enable (detect on rising edge or high level)<br>10b - Enable (detect on falling edge or low level)<br>11b - Enable (detect on any edge) |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21-20<br>WUPE10 | <p>Wake-up Pin Enable for WUU_Pn</p> <p>Enables the external input pin for wake-up. This field configures the edge detection as follows:</p> <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> <p>00b - Disable<br/>01b - Enable (detect on rising edge or high level)<br/>10b - Enable (detect on falling edge or low level)<br/>11b - Enable (detect on any edge)</p> |
| 19-18<br>WUPE9  | <p>Wake-up Pin Enable for WUU_Pn</p> <p>Enables the external input pin for wake-up. This field configures the edge detection as follows:</p> <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> <p>00b - Disable<br/>01b - Enable (detect on rising edge or high level)<br/>10b - Enable (detect on falling edge or low level)<br/>11b - Enable (detect on any edge)</p> |
| 17-16<br>WUPE8  | <p>Wake-up Pin Enable for WUU_Pn</p> <p>Enables the external input pin for wake-up. This field configures the edge detection as follows:</p> <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> <p>00b - Disable<br/>01b - Enable (detect on rising edge or high level)<br/>10b - Enable (detect on falling edge or low level)<br/>11b - Enable (detect on any edge)</p> |
| 15-14           | <p>Wake-up Pin Enable for WUU_Pn</p> <p>Enables the external input pin for wake-up. This field configures the edge detection as follows:</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field              | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WUPE7              | <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> 00b - Disable<br>01b - Enable (detect on rising edge or high level)<br>10b - Enable (detect on falling edge or low level)<br>11b - Enable (detect on any edge)                                                                                                                                   |
| 13-12<br>WUPE6     | Wake-up Pin Enable for WUU_Pn<br>Enables the external input pin for wake-up. This field configures the edge detection as follows: <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> 00b - Disable<br>01b - Enable (detect on rising edge or high level)<br>10b - Enable (detect on falling edge or low level)<br>11b - Enable (detect on any edge) |
| 11-10<br>Reserved5 | Reserved <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> 00b - Not supported<br>01b - Not supported<br>10b - Not supported<br>11b - Not supported                                                                                                                                                                                                |
| 9-8<br>Reserved4   | Reserved <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <ul style="list-style-type: none"> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.           <ul style="list-style-type: none"> <li>00b - Not supported</li> <li>01b - Not supported</li> <li>10b - Not supported</li> <li>11b - Not supported</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 7-6<br>Reserved3 | <p>Reserved</p> <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.           <ul style="list-style-type: none"> <li>00b - Not supported</li> <li>01b - Not supported</li> <li>10b - Not supported</li> <li>11b - Not supported</li> </ul> </li> </ul>                                                                                                                                                                                                    |
| 5-4<br>WUPE2     | <p>Wake-up Pin Enable for WUU_Pn</p> <p>Enables the external input pin for wake-up. This field configures the edge detection as follows:</p> <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.           <ul style="list-style-type: none"> <li>00b - Disable</li> <li>01b - Enable (detect on rising edge or high level)</li> <li>10b - Enable (detect on falling edge or low level)</li> <li>11b - Enable (detect on any edge)</li> </ul> </li> </ul> |
| 3-2<br>Reserved1 | <p>Reserved</p> <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.           <ul style="list-style-type: none"> <li>00b - Not supported</li> <li>01b - Not supported</li> </ul> </li> </ul>                                                                                                                                                                                                                                                              |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | 10b - Not supported<br>11b - Not supported                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1-0<br>Reserved0 | Reserved <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> 00b - Not supported<br>01b - Not supported<br>10b - Not supported<br>11b - Not supported |

### 16.7.1.5 Pin Enable 2 (PE2)

#### Offset

| Register | Offset |
|----------|--------|
| PE2      | Ch     |

#### Function

Contains the field to enable and select the edge detect type for the available external wake-up input pins in the range from WUU\_P16 to WUU\_P31.

#### NOTE

- Do not modify the value of PE2[WUPE $n$ ] when its corresponding PMC[WUPMC $n$ ] = 1.
- VSYS warm reset resets this register.

#### Diagram

| Bits  | 31       | 30 | 29     | 28 | 27     | 26 | 25     | 24 | 23     | 22 | 21     | 20 | 19     | 18 | 17 | 16 |
|-------|----------|----|--------|----|--------|----|--------|----|--------|----|--------|----|--------|----|----|----|
| R     | Reserved |    |        |    | WUPE28 |    | WUPE27 |    | WUPE26 |    | WUPE25 |    | WUPE24 |    |    |    |
| W     |          |    |        |    |        |    |        |    |        |    |        |    |        |    |    |    |
| Reset | 0        | 0  | 0      | 0  | 0      | 0  | 0      | 0  | 0      | 0  | 0      | 0  | 0      | 0  | 0  | 0  |
| Bits  | 15       | 14 | 13     | 12 | 11     | 10 | 9      | 8  | 7      | 6  | 5      | 4  | 3      | 2  | 1  | 0  |
| R     | WUPE23   |    | WUPE22 |    | 0      |    | WUPE20 |    | WUPE19 |    | WUPE18 |    | 0      |    | 0  |    |
| W     |          |    |        |    |        |    |        |    |        |    |        |    |        |    |    |    |
| Reset | 0        | 0  | 0      | 0  | 0      | 0  | 0      | 0  | 0      | 0  | 0      | 0  | 0      | 0  | 0  | 0  |

## Fields

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-26<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 25-24<br>WUPE28 | <p>Wake-up Pin Enable for WUU_Pn</p> <p>Enables the external input pin for wake-up and configures the edge detection.</p> <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> <p>00b - Disable<br/>01b - Enable (detect on rising edge or high level)<br/>10b - Enable (detect on falling edge or low level)<br/>11b - Enable (detect on any edge)</p> |
| 23-22<br>WUPE27 | <p>Wake-up Pin Enable for WUU_Pn</p> <p>Enables the external input pin for wake-up and configures the edge detection.</p> <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> <p>00b - Disable<br/>01b - Enable (detect on rising edge or high level)<br/>10b - Enable (detect on falling edge or low level)<br/>11b - Enable (detect on any edge)</p> |
| 21-20<br>WUPE26 | <p>Wake-up Pin Enable for WUU_Pn</p> <p>Enables the external input pin for wake-up and configures the edge detection.</p> <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> <p>00b - Disable<br/>01b - Enable (detect on rising edge or high level)<br/>10b - Enable (detect on falling edge or low level)</p>                                       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | 11b - Enable (detect on any edge)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 19-18<br>WUPE25 | <p>Wake-up Pin Enable for WUU_Pn</p> <p>Enables the external input pin for wake-up and configures the edge detection.</p> <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> <p>00b - Disable</p> <p>01b - Enable (detect on rising edge or high level)</p> <p>10b - Enable (detect on falling edge or low level)</p> <p>11b - Enable (detect on any edge)</p> |
| 17-16<br>WUPE24 | <p>Wake-up Pin Enable for WUU_Pn</p> <p>Enables the external input pin for wake-up and configures the edge detection.</p> <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> <p>00b - Disable</p> <p>01b - Enable (detect on rising edge or high level)</p> <p>10b - Enable (detect on falling edge or low level)</p> <p>11b - Enable (detect on any edge)</p> |
| 15-14<br>WUPE23 | <p>Wake-up Pin Enable for WUU_Pn</p> <p>Enables the external input pin for wake-up and configures the edge detection.</p> <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> <p>00b - Disable</p> <p>01b - Enable (detect on rising edge or high level)</p> <p>10b - Enable (detect on falling edge or low level)</p> <p>11b - Enable (detect on any edge)</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field               | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13-12<br>WUPE22     | <p>Wake-up Pin Enable for WUU_Pn</p> <p>Enables the external input pin for wake-up and configures the edge detection.</p> <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> <p>00b - Disable<br/>01b - Enable (detect on rising edge or high level)<br/>10b - Enable (detect on falling edge or low level)<br/>11b - Enable (detect on any edge)</p> |
| 11-10<br>Reserved21 | <p>Reserved</p> <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> <p>00b - Not supported<br/>01b - Not supported<br/>10b - Not supported<br/>11b - Not supported</p>                                                                                                                                                                                 |
| 9-8<br>WUPE20       | <p>Wake-up Pin Enable for WUU_Pn</p> <p>Enables the external input pin for wake-up and configures the edge detection.</p> <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> <p>00b - Disable<br/>01b - Enable (detect on rising edge or high level)<br/>10b - Enable (detect on falling edge or low level)<br/>11b - Enable (detect on any edge)</p> |
| 7-6<br>WUPE19       | <p>Wake-up Pin Enable for WUU_Pn</p> <p>Enables the external input pin for wake-up and configures the edge detection.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> 00b - Disable<br>01b - Enable (detect on rising edge or high level)<br>10b - Enable (detect on falling edge or low level)<br>11b - Enable (detect on any edge)                                                                                                                |
| 5-4<br>WUPE18     | Wake-up Pin Enable for WUU_Pn<br>Enables the external input pin for wake-up and configures the edge detection. <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> 00b - Disable<br>01b - Enable (detect on rising edge or high level)<br>10b - Enable (detect on falling edge or low level)<br>11b - Enable (detect on any edge) |
| 3-2<br>Reserved17 | Reserved <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> 00b - Not supported<br>01b - Not supported<br>10b - Not supported<br>11b - Not supported                                                                                                                                                                             |
| 1-0<br>Reserved16 | Reserved <ul style="list-style-type: none"> <li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <ul style="list-style-type: none"> <li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level.</li> <li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge.</li> </ul> 00b - Not supported<br>01b - Not supported<br>10b - Not supported<br>11b - Not supported |

### 16.7.1.6 Module Interrupt Enable (ME)

#### Offset

| Register | Offset |
|----------|--------|
| ME       | 18h    |

#### Function

Contains the bits to enable an on-chip module interrupt as a wake-up source.

#### NOTE

VSYS warm reset resets this register.

#### Diagram

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

#### Fields

| Field | Function |
|-------|----------|
| 31    | Reserved |
| —     |          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function |
|-------|----------|
| 30    | Reserved |
| —     |          |
| 29    | Reserved |
| —     |          |
| 28    | Reserved |
| —     |          |
| 27    | Reserved |
| —     |          |
| 26    | Reserved |
| —     |          |
| 25    | Reserved |
| —     |          |
| 24    | Reserved |
| —     |          |
| 23    | Reserved |
| —     |          |
| 22    | Reserved |
| —     |          |
| 21    | Reserved |
| —     |          |
| 20    | Reserved |
| —     |          |
| 19    | Reserved |
| —     |          |
| 18    | Reserved |
| —     |          |
| 17    | Reserved |
| —     |          |
| 16    | Reserved |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                      |
|-------|-----------------------------------------------------------------------------------------------|
| —     |                                                                                               |
| 15    | Reserved                                                                                      |
| —     |                                                                                               |
| 14    | Reserved                                                                                      |
| —     |                                                                                               |
| 13    | Reserved                                                                                      |
| —     |                                                                                               |
| 12    | Reserved                                                                                      |
| —     |                                                                                               |
| 11    | Reserved                                                                                      |
| —     |                                                                                               |
| 10    | Reserved                                                                                      |
| —     |                                                                                               |
| 9     | Reserved                                                                                      |
| —     |                                                                                               |
| 8     | Module Interrupt Wake-up Enable for Module 8                                                  |
| WUME8 | Enables an on-chip module interrupt as a wake-up source input.<br>0b - Disable<br>1b - Enable |
| 7     | Reserved                                                                                      |
| —     |                                                                                               |
| 6     | Module Interrupt Wake-up Enable for Module 6                                                  |
| WUME6 | Enables an on-chip module interrupt as a wake-up source input.<br>0b - Disable<br>1b - Enable |
| 5     | Reserved                                                                                      |
| —     |                                                                                               |
| 4     | Reserved                                                                                      |
| —     |                                                                                               |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                              |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3<br>—     | Reserved                                                                                                                                              |
| 2<br>WUME2 | Module Interrupt Wake-up Enable for Module 2<br><br>Enables an on-chip module interrupt as a wake-up source input.<br><br>0b - Disable<br>1b - Enable |
| 1<br>—     | Reserved                                                                                                                                              |
| 0<br>WUME0 | Module Interrupt Wake-up Enable for Module 0<br><br>Enables an on-chip module interrupt as a wake-up source input.<br><br>0b - Disable<br>1b - Enable |

#### 16.7.1.7 Module DMA/Trigger Enable (DE)

##### Offset

| Register | Offset |
|----------|--------|
| DE       | 1Ch    |

##### Function

Contains the bits to enable an on-chip module DMA/trigger request as a wake-up source.

##### NOTE

VSYS warm reset resets this register.

##### Diagram

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

**Fields**

| Field | Function |
|-------|----------|
| 31    | Reserved |
| —     |          |
| 30    | Reserved |
| —     |          |
| 29    | Reserved |
| —     |          |
| 28    | Reserved |
| —     |          |
| 27    | Reserved |
| —     |          |
| 26    | Reserved |
| —     |          |
| 25    | Reserved |
| —     |          |
| 24    | Reserved |
| —     |          |
| 23    | Reserved |
| —     |          |
| 22    | Reserved |
| —     |          |
| 21    | Reserved |
| —     |          |
| 20    | Reserved |
| —     |          |
| 19    | Reserved |
| —     |          |
| 18    | Reserved |
| —     |          |
| 17    | Reserved |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                          |
|-------|---------------------------------------------------------------------------------------------------|
| —     |                                                                                                   |
| 16    | Reserved                                                                                          |
| —     |                                                                                                   |
| 15    | Reserved                                                                                          |
| —     |                                                                                                   |
| 14    | Reserved                                                                                          |
| —     |                                                                                                   |
| 13    | Reserved                                                                                          |
| —     |                                                                                                   |
| 12    | Reserved                                                                                          |
| —     |                                                                                                   |
| 11    | Reserved                                                                                          |
| —     |                                                                                                   |
| 10    | Reserved                                                                                          |
| —     |                                                                                                   |
| 9     | Reserved                                                                                          |
| —     |                                                                                                   |
| 8     | DMA/Trigger Wake-up Enable for Module 8                                                           |
| WUDE8 | Enables an on-chip module DMA/trigger request as a wake-up source.<br>0b - Disable<br>1b - Enable |
| 7     | Reserved                                                                                          |
| —     |                                                                                                   |
| 6     | DMA/Trigger Wake-up Enable for Module 6                                                           |
| WUDE6 | Enables an on-chip module DMA/trigger request as a wake-up source.<br>0b - Disable<br>1b - Enable |
| 5     | Reserved                                                                                          |
| —     |                                                                                                   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                             |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4<br>WUDE4 | DMA/Trigger Wake-up Enable for Module 4<br><br>Enables an on-chip module DMA/trigger request as a wake-up source.<br><br>0b - Disable<br>1b - Enable |
| 3<br>—     | Reserved                                                                                                                                             |
| 2<br>—     | Reserved                                                                                                                                             |
| 1<br>—     | Reserved                                                                                                                                             |
| 0<br>—     | Reserved                                                                                                                                             |

#### 16.7.1.8 Pin Flag (PF)

##### Offset

| Register | Offset |
|----------|--------|
| PF       | 20h    |

##### Function

Contains the wake-up flags indicating which wake-up source caused the chip to exit Power Down (if the corresponding [PMC\[WUPMC \$n\$ \]](#) = 1) or Deep Power Down mode. For Power Down mode, this is the source causing the CPU interrupt flow. For Deep Power Down mode, this is the source causing the chip reset flow.

To clear a flag, write a 1 to the corresponding [PF\[WUF \$n\$ \]](#). If set, the wake-up flag (WUF $n$ ) remains set even if the associated pin wake-up is disabled in its [PE \$m\$ \[WUPE \$n\$ \]](#) field.

##### NOTE

VSYS warm reset resets this register.

**Diagram**

| Bits  | 31       | 30 | 29 | 28        | 27        | 26        | 25        | 24        | 23        | 22        | 21 | 20        | 19        | 18        | 17 | 16 |
|-------|----------|----|----|-----------|-----------|-----------|-----------|-----------|-----------|-----------|----|-----------|-----------|-----------|----|----|
| R     | Reserved |    |    | WUF2<br>8 | WUF2<br>7 | WUF2<br>6 | WUF2<br>5 | WUF2<br>4 | WUF2<br>3 | WUF2<br>2 | 0  | WUF2<br>0 | WUF1<br>9 | WUF1<br>8 | 0  | 0  |
|       |          |    |    | W1C       |    | W1C       | W1C       | W1C       |    |    |
| Reset | 0        | 0  | 0  | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0  | 0         | 0         | 0         | 0  | 0  |
| Bits  | 15       | 14 | 13 | 12        | 11        | 10        | 9         | 8         | 7         | 6         | 5  | 4         | 3         | 2         | 1  | 0  |
| R     | 0        | 0  | 0  | WUF1<br>2 | WUF1<br>1 | WUF1<br>0 | WUF9      | WUF8      | WUF7      | WUF6      | 0  | 0         | 0         | WUF2      | 0  | 0  |
|       |          |    |    | W1C       |    |           | W1C       |           |    |    |
| Reset | 0        | 0  | 0  | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0  | 0         | 0         | 0         | 0  | 0  |

**Fields**

| Field       | Function                                                                                                                                           |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-29<br>—  | Reserved                                                                                                                                           |
| 28<br>WUF28 | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes |
| 27<br>WUF27 | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes |
| 26<br>WUF26 | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes |
| 25<br>WUF25 | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes |
| 24<br>WUF24 | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.                        |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                           |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | 0b - No<br>1b - Yes                                                                                                                                |
| 23<br>WUF23      | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes |
| 22<br>WUF22      | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes |
| 21<br>Reserved21 | Reserved<br>0b - Not supported<br>1b - Not supported                                                                                               |
| 20<br>WUF20      | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes |
| 19<br>WUF19      | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes |
| 18<br>WUF18      | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes |
| 17<br>Reserved17 | Reserved<br>0b - Not supported<br>1b - Not supported                                                                                               |
| 16<br>Reserved16 | Reserved<br>0b - Not supported<br>1b - Not supported                                                                                               |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                           |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>Reserved15 | Reserved<br>0b - Not supported<br>1b - Not supported                                                                                               |
| 14<br>Reserved14 | Reserved<br>0b - Not supported<br>1b - Not supported                                                                                               |
| 13<br>Reserved13 | Reserved<br>0b - Not supported<br>1b - Not supported                                                                                               |
| 12<br>WUF12      | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes |
| 11<br>WUF11      | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes |
| 10<br>WUF10      | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes |
| 9<br>WUF9        | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes |
| 8<br>WUF8        | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes |
| 7<br>WUF7        | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.                        |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                                                           |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
|                | 0b - No<br>1b - Yes                                                                                                                                |
| 6<br>WUF6      | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes |
| 5<br>Reserved5 | Reserved<br>0b - Not supported<br>1b - Not supported                                                                                               |
| 4<br>Reserved4 | Reserved<br>0b - Not supported<br>1b - Not supported                                                                                               |
| 3<br>Reserved3 | Reserved<br>0b - Not supported<br>1b - Not supported                                                                                               |
| 2<br>WUF2      | Wake-up Flag for WUU_Pn<br>Indicates that an enabled external wake-up pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes |
| 1<br>Reserved1 | Reserved<br>0b - Not supported<br>1b - Not supported                                                                                               |
| 0<br>Reserved0 | Reserved<br>0b - Not supported<br>1b - Not supported                                                                                               |

### 16.7.1.9 Pin Filter (FILT)

#### Offset

| Register | Offset |
|----------|--------|
| FILT     | 30h    |

**Function**

Contains control and status fields to enable and configure the digital filter features for an external wake-up pin.

**NOTE**

VSYS warm reset resets this register.

**Diagram**

| Bits  | 31     | 30     | 29       | 28 | 27 | 26 | 25     | 24     | 23       | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|--------|--------|----------|----|----|----|--------|--------|----------|----|----|----|----|----|----|----|
| R     | 0      |        |          |    |    |    |        |        |          |    |    |    |    |    |    |    |
| W     |        |        |          |    |    |    |        |        |          |    |    |    |    |    |    |    |
| Reset | 0      | 0      | 0        | 0  | 0  | 0  | 0      | 0      | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bits  | 15     | 14     | 13       | 12 | 11 | 10 | 9      | 8      | 7        | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     | FILTF2 | FILTE2 | FILTSEL2 |    |    |    | FILTF1 | FILTE1 | FILTSEL1 |    |    |    |    |    |    |    |
| W     | W1C    |        |          |    |    |    | W1C    |        |          |    |    |    |    |    |    |    |
| Reset | 0      | 0      | 0        | 0  | 0  | 0  | 0      | 0      | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Fields**

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 15<br>FILTF2    | Filter 2 Flag<br>Indicates that the filtered external pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 14-13<br>FILTE2 | Filter 2 Enable<br>Enables the filter for wake-up. This field configures the edge detection as follows: <ul style="list-style-type: none"><li>For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level</li><li>For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level</li><li>For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge<ul style="list-style-type: none"><li>00b - Disable</li><li>01b - Enable (Detect on rising edge or high level)</li><li>10b - Enable (Detect on falling edge or low level)</li><li>11b - Enable (Detect on any edge)</li></ul></li></ul> |
| 12-8            | Filter 2 Pin Select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FILTSEL2        | Selects and filters the external pin WUU_P <sub>n</sub> , where <i>n</i> equals the value programmed into FILTSEL2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7<br>FILTF1     | Filter 1 Flag<br>Indicates that the filtered external pin was a source of exiting a low-leakage power mode.<br>0b - No<br>1b - Yes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6-5<br>FILTE1   | Filter 1 Enable<br>Enables the filter for wake-up. This field configures the edge detection as follows: <ul style="list-style-type: none"><li>• For field value = 01b, when configured as an interrupt/DMA request: Detect on rising edge. When configured as a trigger request: Detect on high level</li><li>• For field value = 10b, when configured as an interrupt/DMA request: Detect on falling edge. When configured as a trigger request: Detect on low level</li><li>• For field value = 11b, when configured as an interrupt/DMA request: Detect on any edge<ul style="list-style-type: none"><li>00b - Disable</li><li>01b - Enable (Detect on rising edge or high level)</li><li>10b - Enable (Detect on falling edge or low level)</li><li>11b - Enable (Detect on any edge)</li></ul></li></ul> |
| 4-0<br>FILTSEL1 | Filter 1 Pin Select<br>Selects and filters the external pin WUU_P <sub>n</sub> , where <i>n</i> equals the value programmed into FILTSEL1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

#### 16.7.1.10 Pin DMA/Trigger Configuration 1 (PDC1)

##### Offset

| Register | Offset |
|----------|--------|
| PDC1     | 38h    |

##### Function

Configures the available external wake-up input pins in the range from WUU\_P0 to WUU\_P15 to generate an interrupt, DMA, or a trigger request when detected.

- When configured as an interrupt, the interrupt is asserted when the edge programmed in [Pin Enable 1 \(PE1\)](#) is detected and remains asserted until the corresponding flag is cleared in [Pin Flag \(PF\)](#).
- When configured as a DMA request, the request is asserted when the edge programmed in [Pin Enable 1 \(PE1\)](#) is detected and remains asserted until either the corresponding flag is cleared in [Pin Flag \(PF\)](#) or until the requested DMA transfer is complete.
- When configured as a trigger request, the trigger is asserted when the level programmed in [Pin Enable 1 \(PE1\)](#) is detected and remains asserted when the input pin is asserted. The corresponding flag in [Pin Flag \(PF\)](#) will not be set.

**NOTE**

- Do not modify the value of  $PDC_m[WUPDC_n]$  field when its corresponding  $PMC[WUPMC_n] = 1$ .
- VSYS warm reset resets this register.

**Diagram**

| Bits  | 31     | 30 | 29     | 28 | 27 | 26 | 25      | 24      | 23      | 22     | 21     | 20 | 19 | 18 | 17 | 16 |
|-------|--------|----|--------|----|----|----|---------|---------|---------|--------|--------|----|----|----|----|----|
| R     | 0      | 0  | 0      | 0  | 0  | 0  | WUPDC12 | WUPDC11 | WUPDC10 | WUPDC9 | WUPDC8 |    |    |    |    |    |
| W     |        |    |        |    |    |    |         |         |         |        |        |    |    |    |    |    |
| Reset | 0      | 0  | 0      | 0  | 0  | 0  | 0       | 0       | 0       | 0      | 0      | 0  | 0  | 0  | 0  | 0  |
| Bits  | 15     | 14 | 13     | 12 | 11 | 10 | 9       | 8       | 7       | 6      | 5      | 4  | 3  | 2  | 1  | 0  |
| R     | WUPDC7 |    | WUPDC6 |    | 0  | 0  | 0       | 0       | 0       | 0      | 0      | 0  | 0  | 0  | 0  | 0  |
| W     |        |    |        |    |    |    |         |         |         |        |        |    |    |    |    |    |
| Reset | 0      | 0  | 0      | 0  | 0  | 0  | 0       | 0       | 0       | 0      | 0      | 0  | 0  | 0  | 0  | 0  |

**Fields**

| Field      | Function                                                                                       |
|------------|------------------------------------------------------------------------------------------------|
| 31-30      | Reserved                                                                                       |
| Reserved15 | 00b - Not supported<br>01b - Not supported<br>10b - Not supported<br>11b - Not supported       |
| 29-28      | Reserved                                                                                       |
| Reserved14 | 00b - Not supported<br>01b - Not supported<br>10b - Not supported<br>11b - Not supported       |
| 27-26      | Reserved                                                                                       |
| Reserved13 | 00b - Not supported<br>01b - Not supported<br>10b - Not supported<br>11b - Not supported       |
| 25-24      | Wake-up Pin Configuration for WUU_Pn                                                           |
| WUPDC12    | Configures an external pin as an interrupt, DMA, or trigger wake-up source.<br>00b - Interrupt |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                             |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | 01b - DMA request<br>10b - Trigger event<br>11b - Reserved                                                                                                                                           |
| 23-22<br>WUPDC11 | Wake-up Pin Configuration for WUU_Pn<br>Configures an external pin as an interrupt, DMA, or trigger wake-up source.<br>00b - Interrupt<br>01b - DMA request<br>10b - Trigger event<br>11b - Reserved |
| 21-20<br>WUPDC10 | Wake-up Pin Configuration for WUU_Pn<br>Configures an external pin as an interrupt, DMA, or trigger wake-up source.<br>00b - Interrupt<br>01b - DMA request<br>10b - Trigger event<br>11b - Reserved |
| 19-18<br>WUPDC9  | Wake-up Pin Configuration for WUU_Pn<br>Configures an external pin as an interrupt, DMA, or trigger wake-up source.<br>00b - Interrupt<br>01b - DMA request<br>10b - Trigger event<br>11b - Reserved |
| 17-16<br>WUPDC8  | Wake-up Pin Configuration for WUU_Pn<br>Configures an external pin as an interrupt, DMA, or trigger wake-up source.<br>00b - Interrupt<br>01b - DMA request<br>10b - Trigger event<br>11b - Reserved |
| 15-14<br>WUPDC7  | Wake-up Pin Configuration for WUU_Pn<br>Configures an external pin as an interrupt, DMA, or trigger wake-up source.<br>00b - Interrupt<br>01b - DMA request                                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field              | Function                                                                                                                                                                                             |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                    | 10b - Trigger event<br>11b - Reserved                                                                                                                                                                |
| 13-12<br>WUPDC6    | Wake-up Pin Configuration for WUU_Pn<br>Configures an external pin as an interrupt, DMA, or trigger wake-up source.<br>00b - Interrupt<br>01b - DMA request<br>10b - Trigger event<br>11b - Reserved |
| 11-10<br>Reserved5 | Reserved<br>00b - Not supported<br>01b - Not supported<br>10b - Not supported<br>11b - Not supported                                                                                                 |
| 9-8<br>Reserved4   | Reserved<br>00b - Not supported<br>01b - Not supported<br>10b - Not supported<br>11b - Not supported                                                                                                 |
| 7-6<br>Reserved3   | Reserved<br>00b - Not supported<br>01b - Not supported<br>10b - Not supported<br>11b - Not supported                                                                                                 |
| 5-4<br>WUPDC2      | Wake-up Pin Configuration for WUU_Pn<br>Configures an external pin as an interrupt, DMA, or trigger wake-up source.<br>00b - Interrupt<br>01b - DMA request<br>10b - Trigger event<br>11b - Reserved |
| 3-2<br>Reserved1   | Reserved<br>00b - Not supported                                                                                                                                                                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                             |
|------------------|------------------------------------------------------------------------------------------------------|
|                  | 01b - Not supported<br>10b - Not supported<br>11b - Not supported                                    |
| 1-0<br>Reserved0 | Reserved<br>00b - Not supported<br>01b - Not supported<br>10b - Not supported<br>11b - Not supported |

#### 16.7.1.11 Pin DMA/Trigger Configuration 2 (PDC2)

##### Offset

| Register | Offset |
|----------|--------|
| PDC2     | 3Ch    |

##### Function

Configures the available external wake-up input pins in the range from WUU\_P16 to WUU\_P31 to generate an interrupt, DMA, or a trigger request when detected.

- When configured as an interrupt, the interrupt is asserted when the edge programmed in [Pin Enable 2 \(PE2\)](#) is detected and remains asserted until the corresponding flag is cleared in [Pin Flag \(PF\)](#).
- When configured as a DMA request, the request is asserted when the edge programmed in [Pin Enable 2 \(PE2\)](#) is detected and remains asserted until either the corresponding flag is cleared in [Pin Flag \(PF\)](#) or until the requested DMA transfer is complete.
- When configured as a trigger request, the trigger is asserted when the level programmed in [Pin Enable 2 \(PE2\)](#) is detected and remains asserted when the input pin is asserted. The corresponding flag in [Pin Flag \(PF\)](#) will not be set.

##### NOTE

- Do not modify the value of PDC $n$ [WUPDC $n$ ] field when its corresponding [PMC\[WUPMC \$n\$ \]](#) = 1.
- VSYS warm reset resets this register.

**Diagram**

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

**Fields**

| Field               | Function                                                                                                                                                                                                     |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30<br>WUPDC31    | Wake-up Pin Configuration for WUU_Pn<br><br>Configures an external pin as an interrupt, DMA, or trigger wake-up source.<br><br>00b - Interrupt<br>01b - DMA request<br>10b - Trigger event<br>11b - Reserved |
| 29-28<br>Reserved30 | Reserved<br><br>00b - Not supported<br>01b - Not supported<br>10b - Not supported<br>11b - Not supported                                                                                                     |
| 27-26<br>WUPDC29    | Wake-up Pin Configuration for WUU_Pn<br><br>Configures an external pin as an interrupt, DMA, or trigger wake-up source.<br><br>00b - Interrupt<br>01b - DMA request<br>10b - Trigger event<br>11b - Reserved |
| 25-24<br>WUPDC28    | Wake-up Pin Configuration for WUU_Pn<br><br>Configures an external pin as an interrupt, DMA, or trigger wake-up source.<br><br>00b - Interrupt<br>01b - DMA request<br>10b - Trigger event                   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                                                                         |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | 11b - Reserved                                                                                                                                                                                                                                                                   |
| 23-22<br>WUPDC27 | <p>Wake-up Pin Configuration for WUU_Pn</p> <p>Configures an external pin as an interrupt, DMA, or trigger wake-up source.</p> <ul style="list-style-type: none"> <li>00b - Interrupt</li> <li>01b - DMA request</li> <li>10b - Trigger event</li> <li>11b - Reserved</li> </ul> |
| 21-20<br>WUPDC26 | <p>Wake-up Pin Configuration for WUU_Pn</p> <p>Configures an external pin as an interrupt, DMA, or trigger wake-up source.</p> <ul style="list-style-type: none"> <li>00b - Interrupt</li> <li>01b - DMA request</li> <li>10b - Trigger event</li> <li>11b - Reserved</li> </ul> |
| 19-18<br>WUPDC25 | <p>Wake-up Pin Configuration for WUU_Pn</p> <p>Configures an external pin as an interrupt, DMA, or trigger wake-up source.</p> <ul style="list-style-type: none"> <li>00b - Interrupt</li> <li>01b - DMA request</li> <li>10b - Trigger event</li> <li>11b - Reserved</li> </ul> |
| 17-16<br>WUPDC24 | <p>Wake-up Pin Configuration for WUU_Pn</p> <p>Configures an external pin as an interrupt, DMA, or trigger wake-up source.</p> <ul style="list-style-type: none"> <li>00b - Interrupt</li> <li>01b - DMA request</li> <li>10b - Trigger event</li> <li>11b - Reserved</li> </ul> |
| 15-14<br>WUPDC23 | <p>Wake-up Pin Configuration for WUU_Pn</p> <p>Configures an external pin as an interrupt, DMA, or trigger wake-up source.</p> <ul style="list-style-type: none"> <li>00b - Interrupt</li> <li>01b - DMA request</li> <li>10b - Trigger event</li> <li>11b - Reserved</li> </ul> |
| 13-12            | Wake-up Pin Configuration for WUU_Pn                                                                                                                                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field               | Function                                                                                                                                                                                                               |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| WUPDC22             | <p>Configures an external pin as an interrupt, DMA, or trigger wake-up source.</p> <p>00b - Interrupt<br/>01b - DMA request<br/>10b - Trigger event<br/>11b - Reserved</p>                                             |
| 11-10<br>Reserved21 | <p>Reserved</p> <p>00b - Not supported<br/>01b - Not supported<br/>10b - Not supported<br/>11b - Not supported</p>                                                                                                     |
| 9-8<br>WUPDC20      | <p>Wake-up Pin Configuration for WUU_Pn</p> <p>Configures an external pin as an interrupt, DMA, or trigger wake-up source.</p> <p>00b - Interrupt<br/>01b - DMA request<br/>10b - Trigger event<br/>11b - Reserved</p> |
| 7-6<br>WUPDC19      | <p>Wake-up Pin Configuration for WUU_Pn</p> <p>Configures an external pin as an interrupt, DMA, or trigger wake-up source.</p> <p>00b - Interrupt<br/>01b - DMA request<br/>10b - Trigger event<br/>11b - Reserved</p> |
| 5-4<br>WUPDC18      | <p>Wake-up Pin Configuration for WUU_Pn</p> <p>Configures an external pin as an interrupt, DMA, or trigger wake-up source.</p> <p>00b - Interrupt<br/>01b - DMA request<br/>10b - Trigger event<br/>11b - Reserved</p> |
| 3-2<br>Reserved17   | <p>Reserved</p> <p>00b - Not supported<br/>01b - Not supported<br/>10b - Not supported</p>                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field             | Function                                                                                             |
|-------------------|------------------------------------------------------------------------------------------------------|
|                   | 11b - Not supported                                                                                  |
| 1-0<br>Reserved16 | Reserved<br>00b - Not supported<br>01b - Not supported<br>10b - Not supported<br>11b - Not supported |

### 16.7.1.12 Pin Filter DMA/Trigger Configuration (FDC)

#### Offset

| Register | Offset |
|----------|--------|
| FDC      | 48h    |

#### Function

Configures the external pin filters to generate an interrupt, DMA, or a trigger request when detected.

- When configured as an interrupt, the interrupt is asserted when the edge programmed in  $\text{FILT}_m[\text{FILTE}_n]$  is detected and remains asserted until the corresponding  $\text{FILTF}_n$  flag is cleared.
- When configured as a DMA request, the request is asserted when the edge programmed in  $\text{FILT}_m[\text{FILTE}_n]$  is detected and remains asserted until either the corresponding  $\text{FILTF}_n$  flag is cleared or until the requested DMA transfer is complete.
- When configured as a trigger request, the trigger is asserted when the level programmed in [Pin Filter \(FILT\)](#) is detected and remains asserted when the input pin is asserted. The corresponding  $\text{FILTF}_n$  flag will not be set.

#### NOTE

VSYS warm reset resets this register.

#### Diagram

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

**Fields**

| Field                      | Function                                                                                                                                                                                        |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4<br>—                  | Reserved                                                                                                                                                                                        |
| 3-2: FILTC2<br>1-0: FILTC1 | Filter Configuration for FILTn<br><br>Configures a filter as an interrupt, DMA, or trigger wake-up source.<br><br>00b - Interrupt<br>01b - DMA request<br>10b - Trigger event<br>11b - Reserved |

**16.7.1.13 Pin Mode Configuration (PMC)****Offset**

| Register | Offset |
|----------|--------|
| PMC      | 50h    |

**Function**

Configures the detection logic for the available external wake-up input pins to remain enabled during all power modes, not just during Power Down/ mode.

**NOTE**

VSYS warm reset resets this register.

**Diagram**

| Bits  | 31          | 30 | 29          | 28          | 27          | 26          | 25          | 24          | 23          | 22          | 21 | 20          | 19          | 18          | 17 | 16 |
|-------|-------------|----|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|----|-------------|-------------|-------------|----|----|
| R     | WUPM<br>C31 | 0  | WUPM<br>C29 | WUPM<br>C28 | WUPM<br>C27 | WUPM<br>C26 | WUPM<br>C25 | WUPM<br>C24 | WUPM<br>C23 | WUPM<br>C22 | 0  | WUPM<br>C20 | WUPM<br>C19 | WUPM<br>C18 | 0  | 0  |
| W     |             |    |             |             |             |             |             |             |             |             |    |             |             |             |    |    |
| Reset | 0           | 0  | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0  | 0           | 0           | 0           | 0  | 0  |
| Bits  | 15          | 14 | 13          | 12          | 11          | 10          | 9           | 8           | 7           | 6           | 5  | 4           | 3           | 2           | 1  | 0  |
| R     | 0           | 0  | 0           | WUPM<br>C12 | WUPM<br>C11 | WUPM<br>C10 | WUPM<br>C9  | WUPM<br>C8  | WUPM<br>C7  | WUPM<br>C6  | 0  | 0           | 0           | WUPM<br>C2  | 0  | 0  |
| W     |             |    |             |             |             |             |             |             |             |             |    |             |             |             |    |    |
| Reset | 0           | 0  | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0  | 0           | 0           | 0           | 0  | 0  |

**Fields**

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>WUPMC31    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> <p>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> |
| 30<br>Reserved30 | <p>Reserved</p> <p>0b - Not supported</p> <p>1b - Not supported</p>                                                                                                                                                                                                                                                                                                                                                                                           |
| 29<br>WUPMC29    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> <p>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> |
| 28<br>WUPMC28    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> <p>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> |
| 27<br>WUPMC27    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> <p>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> |
| 26<br>WUPMC26    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> <p>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> |
| 25<br>WUPMC25    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p>                                                                                                                                                                                                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> <p>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p>                                                                                                                                                |
| 24<br>WUPMC24    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> <p>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> |
| 23<br>WUPMC23    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> <p>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> |
| 22<br>WUPMC22    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> <p>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> |
| 21<br>Reserved21 | <p>Reserved</p> <p>0b - Not supported</p> <p>1b - Not supported</p>                                                                                                                                                                                                                                                                                                                                                                                           |
| 20<br>WUPMC20    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> <p>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> |
| 19<br>WUPMC19    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p>                                                                                                                                                    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | 1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).                                                                                                                                                                                                                                                                                                                   |
| 18<br>WUPMC18    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> <p>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> |
| 17<br>Reserved17 | <p>Reserved</p> <p>0b - Not supported</p> <p>1b - Not supported</p>                                                                                                                                                                                                                                                                                                                                                                                           |
| 16<br>Reserved16 | <p>Reserved</p> <p>0b - Not supported</p> <p>1b - Not supported</p>                                                                                                                                                                                                                                                                                                                                                                                           |
| 15<br>Reserved15 | <p>Reserved</p> <p>0b - Not supported</p> <p>1b - Not supported</p>                                                                                                                                                                                                                                                                                                                                                                                           |
| 14<br>Reserved14 | <p>Reserved</p> <p>0b - Not supported</p> <p>1b - Not supported</p>                                                                                                                                                                                                                                                                                                                                                                                           |
| 13<br>Reserved13 | <p>Reserved</p> <p>0b - Not supported</p> <p>1b - Not supported</p>                                                                                                                                                                                                                                                                                                                                                                                           |
| 12<br>WUPMC12    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> <p>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> |
| 11<br>WUPMC11    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p>                                                                                                                                                    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | 1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).                                                                                                                                                                                                                                                                                                                   |
| 10<br>WUPMC10  | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> <p>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> |
| 9<br>WUPMC9    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> <p>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> |
| 8<br>WUPMC8    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> <p>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> |
| 7<br>WUPMC7    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> <p>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> |
| 6<br>WUPMC6    | <p>Wake-up Pin Mode Configuration for WUU_Pn</p> <p>Configures an external wake-up pin to provide active detection during all power modes.</p> <p>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> <p>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).</p> |
| 5<br>Reserved5 | <p>Reserved</p> <p>0b - Not supported</p> <p>1b - Not supported</p>                                                                                                                                                                                                                                                                                                                                                                                           |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4<br>Reserved4 | Reserved<br>0b - Not supported<br>1b - Not supported                                                                                                                                                                                                                                                                                                                                                                                       |
| 3<br>Reserved3 | Reserved<br>0b - Not supported<br>1b - Not supported                                                                                                                                                                                                                                                                                                                                                                                       |
| 2<br>WUPMC2    | Wake-up Pin Mode Configuration for WUU_Pn<br>Configures an external wake-up pin to provide active detection during all power modes.<br>0b - Active only during a low-leakage mode. You can modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn).<br>1b - Active during all power modes. Do not modify the corresponding fields within Pin Enable (PEn) or Pin DMA/Trigger Configuration (PDCn). |
| 1<br>Reserved1 | Reserved<br>0b - Not supported<br>1b - Not supported                                                                                                                                                                                                                                                                                                                                                                                       |
| 0<br>Reserved0 | Reserved<br>0b - Not supported<br>1b - Not supported                                                                                                                                                                                                                                                                                                                                                                                       |

#### 16.7.1.14 Pin Filter Mode Configuration (FMC)

##### Offset

| Register | Offset |
|----------|--------|
| FMC      | 58h    |

##### Function

Configures the detection logic for external pin filters to remain enabled during all power modes, not just during Power Down/Deep Power Down mode.

##### NOTE

VSYS warm reset resets this register.

**Diagram**

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

**Fields**

| Field         | Function                                                                                                                                                                                                                                   |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2          | Reserved                                                                                                                                                                                                                                   |
| —             |                                                                                                                                                                                                                                            |
| 1-0<br>FILTMn | <p>Filter Mode for FILTn</p> <p>Configures an external wake-up pin filter to provide active detection during all power modes.</p> <p>0b - Active only during Power Down/Deep Power Down mode</p> <p>1b - Active during all power modes</p> |

# Chapter 17

## AND/OR INVERT (AOI)

### 17.1 Chip-specific AOI information

Table 86. Reference links to related information

| Topic                | Related module | Reference                                     |
|----------------------|----------------|-----------------------------------------------|
| Full description     | AOI            | <a href="#">AOI</a>                           |
| System memory map    |                | <a href="#">Memory map</a>                    |
| Clocking             |                | <a href="#">Clock distribution</a>            |
| Power Management     |                | <a href="#">Power Management</a>              |
| Signal multiplexing  | Port control   | <a href="#">Signal multiplexing</a>           |
| Peripheral Input Mux | INPUTMUX       | <a href="#">Peripheral Input multiplexing</a> |

#### 17.1.1 Module instances

This device has one instance of AOI (AOI0).

### 17.2 Overview

AOI supports the generation of a configurable number of EVENT signals. Each output  $\text{EVENT}_n$  is a configurable AOI function of four associated AOI inputs:  $A_n$ ,  $B_n$ ,  $C_n$ , and  $D_n$ , where  $n$  represents the channel number.

The AOI controller is a target peripheral module that connects event input indicators from a variety of modules and generates event output signals routed to other peripherals. You can access its programming model through the standard IPS target interface.

You can configure AOI to implement different Boolean functions.

#### 17.2.1 Block diagram

AOI supports 4 event outputs, each representing a programmable, combinational Boolean function.

**NOTE**

The connections from AOI outputs to other functions are chip-specific.



Figure 25. Block diagram

MCX A153, A152, A143, A142 Reference Manual, Rev. 4, 01/2024

## 17.2.2 Features

- Enables you to create combinational Boolean events for use as hardware triggers:
  - Each channel includes four event inputs and one output
  - Evaluation of a combinational Boolean expression as the sum of four products, where each product term includes all four selected input sources available as true or complement values
  - Event output is formed as purely combinational logic and operates as a hardware trigger
- Includes a memory-mapped chip connected to the target peripheral (IPS) bus (programming model organized per channel for simplified software)

## 17.3 Functional description

AOI is highly programmable—you can use it for creating combinational Boolean outputs for use as hardware triggers. Each AOI output channel, as shown in [Figure 25](#), has one logic function: Evaluation of combinational Boolean expression as a sum of four products, where each product term includes all four selected input sources available as true or complement values.

### 17.3.1 Modes of operation

AOI does not support any special modes of operation.

### 17.3.2 Clocks

The system uses the bus clock for register accesses, but AOI functions are asynchronous and do not use a clock.

### 17.3.3 Interrupts

This module has no interrupts.

## 17.4 External signals

This module has no external signals.

## 17.5 Initialization

This module does not require initialization.

## 17.6 Application information

The following sections describe configuration examples and Boolean expressions that you could use when programming AOI for your use.

### 17.6.1 Configuration examples for Boolean function evaluation

This section presents examples of the programming model configuration for simple Boolean expressions.

AOI provides a universal Boolean function generator using a four-term sum of product expression. Each product term contains true or complement values of the four selected event inputs ( $A_n$ ,  $B_n$ ,  $C_n$ , and  $D_n$ ). See [Code Listing 1](#) that presents a  $4 \times 4$  Boolean expression defining the event output:

```

EVENTn
= (0,An,~An,1) & (0,Bn,~Bn,1) & (0,Cn,~Cn,1) & (0,Dn,~Dn,1) // product term 0
| (0,An,~An,1) & (0,Bn,~Bn,1) & (0,Cn,~Cn,1) & (0,Dn,~Dn,1) // product term 1

```

```

| (0,An,~An,1) & (0,Bn,~Bn,1) & (0,Cn,~Cn,1) & (0,Dn,~Dn,1) // product term 2
| (0,An,~An,1) & (0,Bn,~Bn,1) & (0,Cn,~Cn,1) & (0,Dn,~Dn,1) // product term 3

```

#### Code Listing 1. Boolean expression defining event inputs (An, Bn, Cn, and Dn)

You can configure each selected input term in each product term to produce a logical 0 or 1, or pass the true or complement value of the selected event input. Each product term uses 8 bits of configuration information, 2 bits for each of the four selected event inputs. See [Code Listing 2](#) that presents the actual Boolean expression implemented in each channel:

```

EVENTn
= (PT0_AC[0] & An | PT0_AC[1] & ~An) // product term 0
& (PT0_BC[0] & Bn | PT0_BC[1] & ~Bn)
& (PT0_CC[0] & Cn | PT0_CC[1] & ~Cn)
& (PT0_DC[0] & Dn | PT0_DC[1] & ~Dn)

| (PT1_AC[0] & An | PT1_AC[1] & ~An) // product term 1
& (PT1_BC[0] & Bn | PT1_BC[1] & ~Bn)
& (PT1_CC[0] & Cn | PT1_CC[1] & ~Cn)
& (PT1_DC[0] & Dn | PT1_DC[1] & ~Dn)

| (PT2_AC[0] & An | PT2_AC[1] & ~An) // product term 2
& (PT2_BC[0] & Bn | PT2_BC[1] & ~Bn)
& (PT2_CC[0] & Cn | PT2_CC[1] & ~Cn)
& (PT2_DC[0] & Dn | PT2_DC[1] & ~Dn)

| (PT3_AC[0] & An | PT3_AC[1] & ~An) // product term 3
& (PT3_BC[0] & Bn | PT3_BC[1] & ~Bn)
& (PT3_CC[0] & Cn | PT3_CC[1] & ~Cn)
& (PT3_DC[0] & Dn | PT3_DC[1] & ~Dn)

```

#### Code Listing 2. Boolean expressions for EVENTn

The combined fields of [{Boolean Function Term 0 and 1 Configuration for EVENTn \(BFCRT010 - BFCRT013\), Boolean Function Term 2 and 3 Configuration for EVENTn \(BFCRT230 - BFCRT233\)}](#) correspond to the  $\text{PT}\{0-3\}_{\{A,B,C,D\}C[1:0]}$  terms in the aforementioned example.

Consider the settings of the combined 32-bit registers [{Boolean Function Term 0 and 1 Configuration for EVENTn \(BFCRT010 - BFCRT013\), Boolean Function Term 2 and 3 Configuration for EVENTn \(BFCRT230 - BFCRT233\)}](#) for several simple Boolean expressions, as shown in [Table 87](#).

Table 87. BFCRTn values for simple boolean expressions

| Event output expression | PT0       | PT1    | PT2 | PT3 | <a href="#">{Boolean Function Term 0 and 1 Configuration for EVENTn (BFCRT010 - BFCRT013), Boolean Function Term 2 and 3 Configuration for EVENTn (BFCRT230 - BFCRT233)}</a> |
|-------------------------|-----------|--------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A & B                   | A & B     | 0      | 0   | 0   | 01011111_00000000_00000000_00000000                                                                                                                                          |
| A & B & C               | A & B & C | 0      | 0   | 0   | 01010111_00000000_00000000_00000000                                                                                                                                          |
| (A & B & C) + D         | A & B & C | D      | 0   | 0   | 01010111_11111101_00000000_00000000                                                                                                                                          |
| A + B + C + D           | A         | B      | C   | D   | 01111111_11011111_11110111_11111101                                                                                                                                          |
| (A & ~B) + (~A & B)     | A & ~B    | ~A & B | 0   | 0   | 01101111_10011111_00000000_00000000                                                                                                                                          |

As explained through the aforementioned examples, the resulting logic provides a simple yet powerful Boolean function evaluation for defining an event output.

## 17.7 AOI register descriptions

You can access the AOI programming model via a 16-bit peripheral bus connection. AOI is designed to support 16-bit accesses only. Other accesses are undefined.

AOI supports a specific number of event outputs. Each output EVENT $n$  outputs a four-term AOI function of four binary inputs: A $n$ , B $n$ , C $n$ , and D $n$ . A pair of 16-bit registers configures this four-term AOI function: [Boolean Function Term 0 and 1 Configuration for EVENTn \(BFCRT010 - BFCRT013\)](#) and [Boolean Function Term 2 and 3 Configuration for EVENTn \(BFCRT230 - BFCRT233\)](#) define the configuration for the evaluation of the Boolean function defining EVENT $n$ , where  $n$  is the event output channel number. [Boolean Function Term 0 and 1 Configuration for EVENTn \(BFCRT010 - BFCRT013\)](#) defines the configuration of product terms 0 and 1, and [Boolean Function Term 2 and 3 Configuration for EVENTn \(BFCRT230 - BFCRT233\)](#) defines the configuration of product terms 2 and 3.

AOI provides a universal Boolean function generator using a four-term sum of product expression with each product term containing true or complement values of the four selected event inputs (A $n$ , B $n$ , C $n$ , and D $n$ ). Specifically, the following "4 x 4" Boolean expression defines the EVENT $n$  output:

```

EVENTTn
term 0      = (0,An,~An,1) & (0,Bn,~Bn,1) & (0,Cn,~Cn,1) & (0,Dn,~Dn,1) // product
term 1      | (0,An,~An,1) & (0,Bn,~Bn,1) & (0,Cn,~Cn,1) & (0,Dn,~Dn,1) // product
term 2      | (0,An,~An,1) & (0,Bn,~Bn,1) & (0,Cn,~Cn,1) & (0,Dn,~Dn,1) // product
term 3      | (0,An,~An,1) & (0,Bn,~Bn,1) & (0,Cn,~Cn,1) & (0,Dn,~Dn,1) // product

```

**Code Listing 3. Boolean expression defining the EVENT $n$  output**

Using the aforementioned expression, you can configure each selected input in each product term to produce a logical 0 or 1 or pass the true or complement value of the selected event input. Each product term uses 8 bits of configuration information, 2 bits for each of the four selected event inputs. The resulting logic provides a simple yet powerful Boolean function evaluation for defining an event output.

These AOI functions are combinational in nature. You must sample and use them synchronously.

### 17.7.1 AOI memory map

AOI0 base address: 4008\_9000h

| Offset | Register                                                                          | Width<br>(In bits) | Access | Reset value |
|--------|-----------------------------------------------------------------------------------|--------------------|--------|-------------|
| 0h     | <a href="#">Boolean Function Term 0 and 1 Configuration for EVENT0 (BFCRT010)</a> | 16                 | RW     | 0000h       |
| 2h     | <a href="#">Boolean Function Term 2 and 3 Configuration for EVENT0 (BFCRT230)</a> | 16                 | RW     | 0000h       |
| 4h     | <a href="#">Boolean Function Term 0 and 1 Configuration for EVENT1 (BFCRT011)</a> | 16                 | RW     | 0000h       |
| 6h     | <a href="#">Boolean Function Term 2 and 3 Configuration for EVENT1 (BFCRT231)</a> | 16                 | RW     | 0000h       |
| 8h     | <a href="#">Boolean Function Term 0 and 1 Configuration for EVENT2 (BFCRT012)</a> | 16                 | RW     | 0000h       |
| Ah     | <a href="#">Boolean Function Term 2 and 3 Configuration for EVENT2 (BFCRT232)</a> | 16                 | RW     | 0000h       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset | Register                                                             | Width<br>(In bits) | Access | Reset value |
|--------|----------------------------------------------------------------------|--------------------|--------|-------------|
| Ch     | Boolean Function Term 0 and 1 Configuration for EVENT3<br>(BFCRT013) | 16                 | RW     | 0000h       |
| Eh     | Boolean Function Term 2 and 3 Configuration for EVENT3<br>(BFCRT233) | 16                 | RW     | 0000h       |

### 17.7.2 Boolean Function Term 0 and 1 Configuration for EVENTn (BFCRT010 - BFCRT013)

#### Offset

| Register | Offset |
|----------|--------|
| BFCRT010 | 0h     |
| BFCRT011 | 4h     |
| BFCRT012 | 8h     |
| BFCRT013 | Ch     |

#### Function

Configures the Boolean function for terms 0 and 1 of EVENTn.

#### Diagram

| Bits  | 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|--------|--------|--------|--------|--------|--------|--------|--------|---|---|---|---|---|---|---|---|
| R     | PT0_AC | PT0_BC | PT0_CC | PT0_DC | PT1_AC | PT1_BC | PT1_CC | PT1_DC |   |   |   |   |   |   |   |   |
| W     | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Reset | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

#### Fields

| Field           | Function                                                                                                                                                                                                                                                        |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-14<br>PT0_AC | Product Term 0, Input A Configuration<br><br>Defines the Boolean evaluation associated with the selected input A in product term 0.<br><br>00b - Force input A to become 0<br>01b - Pass input A<br>10b - Complement input A<br>11b - Force input A to become 1 |
| 13-12           | Product Term 0, Input B Configuration                                                                                                                                                                                                                           |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                  |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PT0_BC          | <p>Defines the Boolean evaluation associated with the selected input B in product term 0.</p> <p>00b - Force input B to become 0<br/>01b - Pass input B<br/>10b - Complement input B<br/>11b - Force input B to become 1</p>                                              |
| 11-10<br>PT0_CC | <p>Product Term 0, Input C Configuration</p> <p>Defines the Boolean evaluation associated with the selected input C in product term 0.</p> <p>00b - Force input C to become 0<br/>01b - Pass input C<br/>10b - Complement input C<br/>11b - Force input C to become 1</p> |
| 9-8<br>PT0_DC   | <p>Product Term 0, Input D Configuration</p> <p>Defines the Boolean evaluation associated with the selected input D in product term 0.</p> <p>00b - Force input D to become 0<br/>01b - Pass input D<br/>10b - Complement input D<br/>11b - Force input D to become 1</p> |
| 7-6<br>PT1_AC   | <p>Product Term 1, Input A Configuration</p> <p>Defines the Boolean evaluation associated with the selected input A in product term 1.</p> <p>00b - Force input A to become 0<br/>01b - Pass input A<br/>10b - Complement input A<br/>11b - Force input A to become 1</p> |
| 5-4<br>PT1_BC   | <p>Product Term 1, Input B Configuration</p> <p>Defines the Boolean evaluation associated with the selected input B in product term 1.</p> <p>00b - Force input B to become 0<br/>01b - Pass input B<br/>10b - Complement input B<br/>11b - Force input B to become 1</p> |
| 3-2<br>PT1_CC   | <p>Product Term 1, Input C Configuration</p> <p>Defines the Boolean evaluation associated with the selected input C in product term 1.</p>                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | 00b - Force input C to become 0<br>01b - Pass input C<br>10b - Complement input C<br>11b - Force input C to become 1                                                                                                                                    |
| 1-0<br>PT1_DC | Product Term 1, Input D Configuration<br>Defines the Boolean evaluation associated with the selected input D in product term 1.<br>00b - Force input D to become 0<br>01b - Pass input D<br>10b - Complement input D<br>11b - Force input D to become 1 |

### 17.7.3 Boolean Function Term 2 and 3 Configuration for EVENTn (BFCRT230 - BFCRT233)

#### Offset

| Register | Offset |
|----------|--------|
| BFCRT230 | 2h     |
| BFCRT231 | 6h     |
| BFCRT232 | Ah     |
| BFCRT233 | Eh     |

#### Function

Configures the Boolean function for terms 2 and 3 of EVENT $n$ .

#### Diagram



#### Fields

| Field  | Function                                                                               |
|--------|----------------------------------------------------------------------------------------|
| 15-14  | Product Term 2, Input A Configuration                                                  |
| PT2_AC | Defines the Boolean evaluation associated with the selected input A in product term 2. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | 00b - Force input A to become 0<br>01b - Pass input A<br>10b - Complement input A<br>11b - Force input A to become 1                                                                                                                                    |
| 13-12<br>PT2_BC | Product Term 2, Input B Configuration<br>Defines the Boolean evaluation associated with the selected input B in product term 2.<br>00b - Force input B to become 0<br>01b - Pass input B<br>10b - Complement input B<br>11b - Force input B to become 1 |
| 11-10<br>PT2_CC | Product Term 2, Input C Configuration<br>Defines the Boolean evaluation associated with the selected input C in product term 2.<br>00b - Force input C to become 0<br>01b - Pass input C<br>10b - Complement input C<br>11b - Force input C to become 1 |
| 9-8<br>PT2_DC   | Product Term 2, Input D Configuration<br>Defines the Boolean evaluation associated with the selected input D in product term 2.<br>00b - Force input D to become 0<br>01b - Pass input D<br>10b - Complement input D<br>11b - Force input D to become 1 |
| 7-6<br>PT3_AC   | Product Term 3, Input A Configuration<br>Defines the Boolean evaluation associated with the selected input A in product term 3.<br>00b - Force input A to become 0<br>01b - Pass input A<br>10b - Complement input A<br>11b - Force input to become 1   |
| 5-4<br>PT3_BC   | Product Term 3, Input B Configuration<br>Defines the Boolean evaluation associated with the selected input B in product term 3.<br>00b - Force input B to become 0                                                                                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | 01b - Pass input B<br>10b - Complement input B<br>11b - Force input B to become 1                                                                                                                                                                       |
| 3-2<br>PT3_CC | Product Term 3, Input C Configuration<br>Defines the Boolean evaluation associated with the selected input C in product term 3.<br>00b - Force input C to become 0<br>01b - Pass input C<br>10b - Complement input C<br>11b - Force input C to become 1 |
| 1-0<br>PT3_DC | Product Term 3, Input D Configuration<br>Defines the Boolean evaluation associated with the selected input D in product term 3.<br>00b - Force input D to become 0<br>01b - Pass input D<br>10b - Complement input D<br>11b - Force input D to become 1 |

# Chapter 18

## Core Mode Controller (CMC)

### 18.1 Chip-specific CMC information

Table 88. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | CMC            | <a href="#">CMC</a>                 |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Reset               |                | <a href="#">Reset</a>               |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 18.1.1 Module instances

This device has one instance of CMC module.

### 18.2 Overview

CMC provides the sequencing of the CPU and associated logic through the different operating modes.

This chapter describes the available CPU operating modes, including reset, active mode, and low-power modes.

#### 18.2.1 Block diagram



Figure 26. Block diagram

#### 18.2.2 Features

- Configures the low-power mode options including SRAM retention
- Provides reset controller including reset status register and warm reset configuration
- Provides boot mode register and status bits

### 18.3 Functional description

This section provides the functional description of the block.

### 18.3.1 Modes of operation

The Arm Cortex-M CPU enters a low-power mode with the execution of a WFI or WFE instruction or via the SLEEPONEXIT mechanism. CMC configures the low-power mode that is entered.

The following table describes the low-power modes available to each core.

**Table 89. Operating modes**

| Mode            | Entry                                   | Exit                      | Description                                                                                                                                                                       |
|-----------------|-----------------------------------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Reset           | POR<br>Warm reset<br>WUU via power down | Active                    | <ul style="list-style-type: none"> <li>Core and peripherals are reset</li> <li>SRAM optionally retained on power-down wake-up</li> </ul>                                          |
| Active          | Reset<br>NVIC<br>WUU                    | WFI<br>WFE<br>SLEEPONEXIT | Core executing instructions, peripherals optionally active.                                                                                                                       |
| Deep Sleep      | WFI<br>WFE<br>SLEEPONEXIT               | NVIC<br>Reset             | <ul style="list-style-type: none"> <li>Core waiting for interrupt or event, peripherals optionally active</li> <li>Core and peripherals retain state, SRAM is retained</li> </ul> |
| Power Down      | WFI<br>WFE<br>SLEEPONEXIT               | WUU via Active<br>Reset   | <ul style="list-style-type: none"> <li>Core and peripherals waiting for wakeup</li> <li>Core and peripherals retain state</li> <li>SRAM is optionally retained</li> </ul>         |
| Deep Power Down | WFI<br>WFE<br>SLEEPONEXIT               | WUU via Reset<br>Reset    | Core, peripherals, and SRAM not retained.                                                                                                                                         |

### 18.3.2 Active mode

This section describes power options in Active mode.

#### 18.3.2.1 Flash memory

This section describes the Flash Memory Low-Power mode.

You can place the internal flash memory in Low-Power mode under the following conditions:

- Under software control ([FLASHCR\[FLASHDIS\]](#))
- When CPU is sleeping ([FLASHCR\[FLASHDOZE\]](#))
- When the chip enters a low-power mode

When [FLASHCR\[FLASHDIS\]](#) or [FLASHCR\[FLASHDOZE\]](#) becomes 1, you can configure the internal flash memory to automatically exit Low-Power mode during the access on any attempted access to flash memory space.

[FLASHCR\[FLASHWAKE\]](#) controls this.

When the internal flash memory enters a low-power mode, the wake-up time of the flash memory automatically delays the first access upon exit from Low-Power mode. If there is no access between the internal flash memory exiting Low-Power and subsequent re-entry of Low-Power mode, the wake-up time of the flash memory delays the re-entry.

### 18.3.2.2 System SRAM

The system SRAM is divided into 3 different power partitions. You can individually power gate these partitions either all the time or only in low-power modes. System SRAM contents in a power gated partition are not retained. You must not access system SRAM partitions when they are power gated.

- Write 1 to SRAMDIS[i] to always power gate system SRAM power partition "i".
- Write 1 to SRAMRET[i] to power gate system SRAM power partition "i" during a low-power mode only.

### 18.3.3 Low-power modes

This section describes the low-power modes.

#### 18.3.3.1 Low-power entry

The following steps occur during the Low-Power mode entry sequence.

Table 90. Entry sequence

| Step | CKMODE (min) | LPMODE (min) | Description                                                                                                                                                                       |
|------|--------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | 0h           | 0h           | Core enters Low-Power mode by WFI/WFE instruction or via SLEEPONEXIT.                                                                                                             |
| 2    | 1h           | 0h           | <ul style="list-style-type: none"> <li>• Wake-up interrupt controller is enabled.</li> <li>• Core is clock gated.</li> </ul>                                                      |
| 3    | 3h           | 0h           | <ul style="list-style-type: none"> <li>• Request AHB initiators to enter Low-Power mode.</li> <li>• Wait for acknowledge.</li> <li>• AHB initiators are clock gated.</li> </ul>   |
| 4    | 3h           | 0h           | <ul style="list-style-type: none"> <li>• Request AHB peripherals to enter Low-Power mode.</li> <li>• Wait for acknowledge.</li> <li>• AHB peripherals are clock gated.</li> </ul> |
| 5    | 7h           | 0h           | <ul style="list-style-type: none"> <li>• Request peripherals to enter Low-Power mode.</li> <li>• Wait for acknowledge.</li> <li>• Peripherals are clock gated.</li> </ul>         |
| 6    | Fh           | 0h           | Request power management (regulators, bandgap) to enter Low-Power mode.                                                                                                           |
| 7    | Fh           | 1h           | <ul style="list-style-type: none"> <li>• SRAMs enter Low-Power mode (Deep Sleep).</li> <li>• System clocks are gated.</li> </ul>                                                  |
| 8    | Fh           | 3h           | Power domain is placed in Low-Power retention state (Power-Down).                                                                                                                 |
| 9    | Fh           | 7h           | Power domain is switched off.                                                                                                                                                     |
| 10   | Fh           | Fh           | Regulators are powered off (Deep Power-Down).                                                                                                                                     |

### 18.3.3.2 DMA wakeup

You can configure the DMA to generate a wake-up when a DMA request for configured channel asserts. This is supported when you request the DMA to enter Low-Power mode and retain the DMA state (not in Deep Power-Down).

The DMA wakeup triggers an exit from Low-Power mode for everything except the core, which remains clock gated. Re-enter Low-Power mode after the DMA request negates, and the normal low-power mode entry sequence is followed.

Because a DMA wake-up results in everything except the core from exiting Low-Power mode, you must ensure that other modules not involved in the wakeup remain in a known state. To accomplish this, disable the modules before the initial entry in Low-Power mode or configure the Doze field in selected modules.

If the flash memory is not required during the DMA wakeup, NXP recommends that [FLASHCR\[FLASHDOZE\]](#) = 1.

---

**NOTE**

If the DMA request does not negate due to the DMA transfer, the chip remains in a higher power state until an interrupt or other wake-up sources can wakeup the core.

An interrupt that occurs during a DMA wakeup causes an immediate exit from Low-Power mode without affecting the DMA transfer.

### 18.3.3.3 Power domains

CMC configures Low-Power mode of 1 power domain when the core enters a low-power mode with CKMODE = Fh. You can configure the different power domains to enter different low-power modes .

---

**NOTE**

The MAIN domain LPMODE register setting must always be less than or equal to the LPMODE register setting for all other power domains.

The power domain controlled by the CMC is MAIN.

Configure all power domains to the same Low-Power mode using [Global Power Mode Control \(GPMCTRL\)](#). Alternatively, configure each PMCTRL register to assign an individual low-power mode to each domain.

### 18.3.3.4 Debug in low-power modes

When the debugger asserts CDBGWRUPREQ, it requests the debug logic to power up and enable the functionality depending on [DBGCTL\[SOD\]](#).

- When [DBGCTL\[SOD\]](#) = 0, the core clock remains enabled even when the core is sleeping (CKMODE = 0h). CDBGWRUPACK remains asserted.
- When [DBGCTL\[SOD\]](#) = 1, ignore the debug request when the core sleeps. CDBPWRUPQACK negates when the core is sleeping.

---

**NOTE**

Do not attach a debugger when MAIN power domain is in Deep-Sleep, Power Down, or Deep-Power Down, because the JTAG/SWD logic is powered off.

### 18.3.4 Clocks

- The slow bus clock clocks CMC registers and logic.
- clk\_1M clock clocks the timeout counters.

## 18.3.5 Reset

This section describes the sources of reset and the different resets that you can generate.

### 18.3.5.1 Reset sources

This section describes the different reset sources.

#### Power-on reset (POR)

When you initially apply power to the MCU or the supply voltage is below the POR falling threshold, the POR circuit triggers the POR condition.

The POR condition asserts a cold reset in all power domains. [SRS\[POR\]](#) and [SRS\[VD\]](#) become 1 on a POR condition.

#### Low voltage detect (LVD)

The LVD circuit enables by default and keeps the MCU in reset until the supply voltage rises above the LVD rising threshold. When the LVD circuit is enabled, it triggers an LVD reset condition if the supply voltage is below the LVD falling threshold.

[SRS\[VD\]](#) becomes 1 on an LVD reset condition. The LVD reset condition asserts a cold reset in all power domains. Only the LVD or HVD detection logic is unaffected by LVD or HVD resets.

#### High voltage detect (HVD)

The HVD circuit disables by default, but when enabled, it triggers an HVD reset condition if the supply voltage exceeds the HVD threshold.

[SRS\[VD\]](#) becomes 1 on an HVD reset condition. The HVD reset condition asserts a cold reset in all power domains. Only the LVD or HVD detection logic is unaffected by LVD or HVD resets.

#### Wakeup (WAKEUP)

On a wakeup from Deep-Power Down mode, the power management logic triggers a Wake-up reset in the power domains that had powered off.

The wake-up reset condition asserts a cold reset in all power domains that were powered down. The system power domain, including the RESET\_b pin, is unaffected by a wake-up from Deep-Power Down mode (unless another reset source triggers the wake-up). [SRS\[WAKEUP\]](#) becomes 1 on a wake-up reset condition.

#### External pin reset (RESET\_b)

The RESET\_b pin is a bi-directional open-drain pin with an internal pull-up resistor. The RESET\_b pin function depends on the mode:

- During reset, the RESET\_b drives low until the MCU completes initialization, at which point the RESET\_b pin is released. If the RESET\_b pin asserts externally, then the MCU remains in reset until the RESET\_b input is pulled high.
- During active and low-power modes, the RESET\_b pin can assert externally to force the MCU into the PIN reset condition.

The RESET\_b pin implements a digital filter that you can configure to filter out glitches on the RESET\_b pin that are less than 1-32 CMC clock cycles. The filter bypasses in low-power modes when you disable the CMC clock.

The PIN reset condition asserts a warm reset in all power domains. [SRS\[PIN\]](#) and [SRS\[WARM\]](#) become 1 on a PIN reset condition.

#### Debug access port reset (DAP)

Any debug access port that can initiate a reset request from a connected debugger triggers the DAP reset condition.

The DAP reset condition asserts a warm reset in all power domains. [SRS\[DAP\]](#) and [SRS\[WARM\]](#) become 1 on a DAP reset condition.

### Reset timeout (RSTACK)

The reset state machine includes a timeout counter that is triggered by the reset state machine not progressing within 65536 cycles of the clk\_1M clock. This triggers the RSTACK reset condition.

The RSTACK reset condition asserts a warm reset in all power domains. [SRS\[RSTACK\]](#), [SRS\[FATAL\]](#), and [SRS\[WARM\]](#) become 1 on an RSTACK reset condition.

### Low-power timeout (LPACK)

The low-power entry state machine includes a timeout counter that triggers if a module does not acknowledge entry into Low-Power mode after 65536 cycles of the clk\_1M clock. This triggers the LPACK reset condition.

The LPACK reset condition asserts a warm reset in all power domains. [SRS\[LPACK\]](#) and [SRS\[WARM\]](#) become 1 on an LPACK reset condition.

### System clock generation (SCG)

The system clock generation includes loss of clock and loss of lock monitors that you can configure to generate a reset, this triggers the SCG reset condition.

The SCG reset condition asserts a warm reset in all power domains. [SRS\[SCG\]](#), [SRS\[FATAL\]](#), and [SRS\[WARM\]](#) become 1 on an SCG reset condition.

### Windowed watchdog timer 0 (WWDT0)

The windowed watchdog timer monitors the software by expecting periodic refreshing of the watchdog counter. When this does not occur, it triggers the WWDT0 reset condition.

The WWDT0 reset condition asserts a warm reset in all power domains. [SRS\[WWDT0\]](#) and [SRS\[WARM\]](#) become 1 on a WWDT0 reset condition.

### Software (SW)

The software can request a system reset by configuring the system reset request in the Cortex-M33 core, this triggers the software reset condition.

The software reset condition asserts a warm reset in all power domains. [SRS\[SW\]](#) and [SRS\[WARM\]](#) become 1 on a software reset condition.

### Lockup (LOCKUP)

The Cortex-M33 core enters Lockup state as a result of certain illegal operations, this triggers the LOCKUP reset condition.

The LOCKUP reset condition asserts an MCU reset in all power domains. [SRS\[LOCKUP\]](#) and [SRS\[WARM\]](#) become 1 on a LOCKUP reset condition.

### Code watchdog (CDOG)

CDOG module helps protect the integrity of software by detecting unexpected changes (faults) in the code execution flow. CDOG module configures to reset or interrupt the processor core when the module detects a fault.

The CDOG0 reset condition asserts a warm reset in all power domains. [SRS\[CDOG0\]](#) and [SRS\[WARM\]](#) become 1 on a CDOG0 reset condition.

### JTAG reset (JTAG)

When a JTAG instruction places the chip in reset, it triggers the JTAG reset condition.

The JTAG reset condition asserts a warm reset in all power domains. [SRS\[JTAG\]](#), [SRS\[JTAG\]](#), [SRS\[FATAL\]](#), and [SRS\[WARM\]](#) become 1 on a JTAG reset condition.

### 18.3.5.2 Reset types

This section describes the different resets that you can generate.

#### Cold reset

Each power domain generates a cold reset to reset the debug logic and mode control logic. The cold reset for each power domain can assert as a result of the following events.

- Initial POR of the chip
- LVD or HVD
- Power domain wake-up from Deep-Power Down (varies per domain)

A cold reset does not guarantee the contents of on-chip SRAM.

#### Warm reset

- Cold Reset or any of the remaining warm reset sources generates a warm reset.
- A warm reset resets most of the logic in each power domain.
- Warm resets are divided into fatal reset sources and non-fatal reset sources.

You can configure the non-fatal reset sources to generate an interrupt instead of the warm reset. The warm reset averts if you can clear the non-fatal reset source (including status flag) within 65536 cycles of the clk\_1M clock. Non-fatal resets retain the contents of on-chip SRAM.

You cannot configure the fatal reset sources to generate an interrupt and do not guarantee the contents of on-chip SRAM.

### 18.3.5.3 Reset sequence

#### Power-on reset

Perform the following steps as part of the POR (or LVD/HVD) sequence:

1. RESET\_b pin drives low and internal reset signals asserted.
2. POR or LVD signals negate and clocks are enabled in their default configuration.
3. Internal reset remains asserted for 8 clock cycles.
4. Internal reset to flash memory and fuse controllers negates and their initialization sequences commence.
5. Initialization sequences for flash memory and fuse complete.
6. Internal trim registers are loaded and RESET\_b pin is tri-stated.
7. Reset state machine waits for RESET\_b pin input to pull high or drive high externally.
8. Internal reset signals negate.
9. Core exits reset and fetches the initial program counter and stack pointer from ROM.

#### Deep-power down wake-up

Perform the following steps as part of the deep-power down wake-up sequence:

1. Internal reset signals asserted.
2. Wake-up signal negates and clocks are enabled in their default configuration.
3. Internal reset remains asserted for 8 clock cycles.
4. Internal reset to flash memory and fuse controllers negates and commence their initialization sequences.
5. Initialization sequences for flash memory and fuse complete.

6. Internal trim registers are loaded.
7. Internal reset signals negate.
8. Core exits reset and fetches the initial program counter and stack pointer from ROM.

A wake-up from deep-power down via the RESET\_b pin follows the warm reset sequence.

#### Warm reset

Perform the following steps as part of the warm reset sequence:

1. RESET\_b pin drives low and internal reset signals asserted.
2. Clocks are enabled in their default configuration.
3. Internal reset remains asserted for 8 clock cycles.
4. Internal reset to flash memory and fuse controllers negates and commence their initialization sequences.
5. Initialization sequences for flash memory and fuse complete.
6. Internal trim registers are loaded and RESET\_b pin is tri-stated.
7. Reset state machine waits for RESET\_b pin input to pull high or drive high externally.
8. Internal reset signals negate.
9. Core exits reset and fetches the initial program counter and stack pointer from ROM.

#### 18.3.6 Interrupts

CMC generates a single interrupt, which [System Reset Interrupt Enable \(SRIE\)](#) configures.

### 18.4 External signals

Table 91. External signals

| Signal    | Description                                                                                                                    | Direction       |
|-----------|--------------------------------------------------------------------------------------------------------------------------------|-----------------|
| RESET_B   | Bidirectional open-drain reset pin with pullup that asserts low during warm reset except when waking up from a low-power mode. | Input or output |
| ISPMODE_n | The input pin is sampled at the end of the RESET_B assertion and stored in <a href="#">Mode (MR0)</a> .                        | Input           |

### 18.5 Initialization

By default, the digital glitch filter is disabled on RESET\_b pin. To enable the filter, configure:

- [RPC\[LPFEN\]](#), [RPC\[FILTEN\]](#), or both.
- [RPC\[FILTCFG\]](#).

### 18.6 Application information

To configure for Deep-Power Down Low-Power mode entry:

1. Write Fh to [Clock Control \(CKCTRL\)](#)
2. Write 8h to [Power Mode Protection \(PMPROT\)](#)

3. Write Fh to Global Power Mode Control (GPMCTRL)
4. Execute WFI instruction

To configure for Power-Down Low-Power mode entry:

1. Write Fh to Clock Control (CKCTRL)
2. Write 2h to Power Mode Protection (PMPROT)
3. Write 3h to Global Power Mode Control (GPMCTRL)
4. Execute WFI instruction

To configure for Deep Sleep Low-Power mode entry:

1. Write Fh to Clock Control (CKCTRL)
2. Write 1h to Power Mode Protection (PMPROT)
3. Write 1h to Global Power Mode Control (GPMCTRL)
4. Execute WFI instruction

## 18.7 Memory map and register descriptions

This section describes the registers in the CMC module.

### 18.7.1 CMC register descriptions

#### NOTE

Different CMC registers reset on different reset types.

#### NOTE

You must read back the last register written to before executing the WFI instruction. This ensures that before the MCU enters the low power mode, all register writes associated with setting up the low power mode are complete, failure to do this may result in the low power mode not being entered correctly.

#### 18.7.1.1 CMC memory map

CMC base address: 4008\_B000h

| Offset | Register                            | Width<br>(In bits) | Access | Reset value |
|--------|-------------------------------------|--------------------|--------|-------------|
| 0h     | Version ID (VERID)                  | 32                 | R      | 0301_0000h  |
| 10h    | Clock Control (CKCTRL)              | 32                 | RW     | 0000_0000h  |
| 14h    | Clock Status (CKSTAT)               | 32                 | RW     | 0000_0000h  |
| 18h    | Power Mode Protection (PMPROT)      | 32                 | RW     | 0000_0000h  |
| 1Ch    | Global Power Mode Control (GPMCTRL) | 32                 | RW     | 0000_0000h  |
| 20h    | Power Mode Control (PMCTRLMAIN)     | 32                 | RW     | 0000_0000h  |
| 80h    | System Reset Status (SRS)           | 32                 | R      | See section |
| 84h    | Reset Pin Control (RPC)             | 32                 | RW     | 0000_0000h  |
| 88h    | Sticky System Reset Status (SSRS)   | 32                 | RW     | 0000_0006h  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset | Register                             | Width<br>(In bits) | Access | Reset value |
|--------|--------------------------------------|--------------------|--------|-------------|
| 8Ch    | System Reset Interrupt Enable (SRIE) | 32                 | RW     | 0000_8800h  |
| 90h    | System Reset Interrupt Flag (SRIF)   | 32                 | RW     | 0000_0000h  |
| 9Ch    | Reset Count Register (RSTCNT)        | 32                 | R      | 0000_0000h  |
| A0h    | Mode (MR0)                           | 32                 | RW     | 0000_0000h  |
| B0h    | Force Mode (FM0)                     | 32                 | RW     | 0000_0000h  |
| E0h    | Flash Control (FLASHCR)              | 32                 | RW     | 0000_0000h  |
| 110h   | Core Control (CORECTL)               | 32                 | RW     | 0000_0000h  |
| 120h   | Debug Control (DBGCTL)               | 32                 | RW     | 0000_0000h  |

### 18.7.1.2 Version ID (VERID)

#### Offset

| Register | Offset |
|----------|--------|
| VERID    | 0h     |

#### Function

Contains version numbers for module design and feature set.

#### Diagram



#### Fields

| Field | Function             |
|-------|----------------------|
| 31-24 | Major Version Number |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field   | Function                                                       |
|---------|----------------------------------------------------------------|
| MAJOR   | Returns the major version number for the module specification. |
| 23-16   | Minor Version Number                                           |
| MINOR   | Returns the minor version number for the module specification. |
| 15-0    | Feature Specification Number                                   |
| FEATURE | Returns the feature set number.                                |

### 18.7.1.3 Clock Control (CKCTRL)

#### Offset

| Register | Offset |
|----------|--------|
| CKCTRL   | 10h    |

#### Function

Configures the amount of clock gating when the core asserts sleeping due to WFI, WFE, or SLEEPONEXIT.

#### NOTE

This register resets on MAIN warm reset.

#### Diagram



#### Fields

| Field      | Function                                                           |
|------------|--------------------------------------------------------------------|
| 31<br>LOCK | Lock<br>Locks the register and blocks writes until the next reset. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | 0b - Allowed<br>1b - Blocked                                                                                                                                                                                                                                                                                                                                                                                    |
| 30-4<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                        |
| 3-0<br>CKMODE | Clocking Mode<br><br>Configures the amount of clock gating when the core enters a low-power mode because of WFI, WFE or SLEEPONEXIT. Configuring CKMODE > 0 requires the SLEEPDEEP field in the Arm core to become 1. Configuring PMCTRLx[LPMODE] > 0 requires writing Fh to CKMODE.<br><br>0000b - No clock gating<br>1111b - Core, platform, and peripheral clocks are gated, and core enters Low-Power mode. |

#### 18.7.1.4 Clock Status (CKSTAT)

##### Offset

| Register | Offset |
|----------|--------|
| CKSTAT   | 14h    |

##### Function

Returns the clock gating status and wake-up source from the previous Low-Power mode entry, provided the core was clock gated. This requires configuring [CKCTRL\[CKMODE\]](#) > 0 and the wake-up event must occur after the core is clock gated. The register contents are only valid when [CKSTAT\[VALID\]](#) = 1.

##### NOTE

This register resets on MAIN warm reset.

##### Diagram

| Bits  | 31    | 30 | 29 | 28 | 27     | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19     | 18 | 17 | 16 |
|-------|-------|----|----|----|--------|----|----|----|----|----|----|----|--------|----|----|----|
| R     | VALID |    |    |    |        |    |    |    | 0  |    |    |    |        |    |    |    |
| W     | W1C   |    |    |    |        |    |    |    |    |    |    |    |        |    |    |    |
| Reset | 0     | 0  | 0  | 0  | 0      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0  | 0  | 0  |
| Bits  | 15    | 14 | 13 | 12 | 11     | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3      | 2  | 1  | 0  |
| R     |       |    |    |    | WAKEUP |    |    |    | 0  |    |    |    | CKMODE |    |    |    |
| W     |       |    |    |    |        |    |    |    |    |    |    |    |        |    |    |    |
| Reset | 0     | 0  | 0  | 0  | 0      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0  | 0  | 0  |

**Fields**

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>VALID    | Clock Status Valid<br><br>Indicates that the core clock was gated since you last wrote 0 to this field.<br><br>0b - Core clock not gated<br>1b - Core clock was gated due to Low-Power mode entry                                                                                                                                                                                                                                                                                                                                                                                                       |
| 30-16<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 15-8<br>WAKEUP | Wake-up Source<br><br>Returns any wake-up sources from the previous Low-Power mode entry.<br><br>[0] - Wake-up source is reset interrupt or wakeup from Deep Power-Down<br>[1] - Wake-up source is debug request<br>[2] - Wake-up source is interrupt<br>[3] - Wake-up source is DMA wakeup<br>[4] - Wake-up source is WUU request<br>[5] - Wake-up source is bus master wakeup<br>[6] - Wake-up source is bus master wakeup<br>[7] - Wake-up source is bus master wakeup<br><br>A wakeup from Deep Power-Down writes 1 to WAKEUP[0]. Depending on Low-Power mode, other wake-up bits may not become 1. |
| 7-4<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3-0<br>CKMODE  | Low Power Status<br><br>Returns the result of the previous Low-Power mode entry.<br><br>0000b - Core clock not gated<br>1111b - Core, platform, and peripheral clocks were gated, and power domain entered Low-Power mode<br><br>All other values are reserved.                                                                                                                                                                                                                                                                                                                                         |

**18.7.1.5 Power Mode Protection (PMPROT)****Offset**

| Register | Offset |
|----------|--------|
| PMPROT   | 18h    |

## Function

Provides protection for entry in low-power modes, you must allow a low-power mode before configuring any Power Mode Control register (PMCTRLx) to that mode.

### NOTE

This register resets on MAIN warm reset.

## Diagram

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

## Fields

| Field         | Function                                                                                                                                                                                                                                                                        |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>LOCK    | Lock Register<br>Locks the register and blocks writes until the next reset.<br>0b - Allowed<br>1b - Blocked                                                                                                                                                                     |
| 30-4<br>—     | Reserved                                                                                                                                                                                                                                                                        |
| 3-0<br>LPMODE | Low-Power Mode<br>Configures the lowest power mode that you can write to PMCTRLx[LPMODE] fields.<br>0000b - Not allowed<br>0001b - Allowed<br>0010b - Allowed<br>0011b - Allowed<br>0100b - Allowed<br>0101b - Allowed<br>0110b - Allowed<br>0111b - Allowed<br>1000b - Allowed |

Table continues on the next page...

*Table continued from the previous page...*

| Field | Function        |
|-------|-----------------|
|       | 1001b - Allowed |
|       | 1010b - Allowed |
|       | 1011b - Allowed |
|       | 1100b - Allowed |
|       | 1101b - Allowed |
|       | 1110b - Allowed |
|       | 1111b - Allowed |

#### 18.7.1.6 Global Power Mode Control (GPMCTRL)

##### Offset

| Register | Offset |
|----------|--------|
| GPMCTRL  | 1Ch    |

##### Function

Updates all PMCTRLx registers with the value written.

##### NOTE

This register resets on MAIN cold reset.

##### Diagram

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

##### Fields

| Field | Function |
|-------|----------|
| 31    | Reserved |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field  | Function                                                                 |
|--------|--------------------------------------------------------------------------|
| —      |                                                                          |
| 30-4   | Reserved                                                                 |
| —      |                                                                          |
| 3-0    | Low-Power Mode                                                           |
| LPMODE | Specifies that all PMCTRLx[LPMODE] fields update with the value written. |

#### 18.7.1.7 Power Mode Control (PMCTRLMAIN)

##### Offset

| Register   | Offset |
|------------|--------|
| PMCTRLMAIN | 20h    |

##### Function

Configures entry into low-power modes for each power domain, provided that the selected power mode is allowed via an appropriate setting of [Power Mode Protection \(PMPROT\)](#), and CKMODE = Fh.

##### NOTE

This register resets by MAIN cold reset.

##### Diagram



##### Fields

| Field | Function |
|-------|----------|
| 31-30 | Reserved |
| —     |          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29-4<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 3-0<br>LPMODE | <p>Low-Power Mode</p> <p>Selects the desired Low-Power mode when a core executes WFI or WFE instruction. Writes to this field are blocked if you have not enabled the protection level using <a href="#">Power Mode Protection (PMPROT)</a>.</p> <p>You must not configure this field for the MAIN domain to a lower power mode than any other power domain.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>See <a href="#">Power domains</a> section for details on allowed combinations.</p> <ul style="list-style-type: none"> <li>0000b - Active/Sleep</li> <li>0001b - Deep Sleep</li> <li>0011b - Power Down</li> <li>0111b - Reserved</li> <li>1111b - Deep-Power Down</li> </ul> |

#### 18.7.1.8 System Reset Status (SRS)

##### Offset

| Register | Offset |
|----------|--------|
| SRS      | 80h    |

##### Function

Updates on every MAIN warm reset to indicate the type/source of the most recent reset.

##### Diagram

| Bits  | 31         | 30 | 29        | 28   | 27        | 26         | 25  | 24  | 23 | 22    | 21   | 20 | 19 | 18  | 17         | 16 |
|-------|------------|----|-----------|------|-----------|------------|-----|-----|----|-------|------|----|----|-----|------------|----|
| R     | 0          | 0  | 0         | JTAG | 0         | CDOG<br>0  | 0   | 0   | 0  | 0     | 0    | 0  | 0  | 0   | 0          | 0  |
| W     |            |    |           |      |           |            |     |     |    |       |      |    |    |     |            |    |
| Reset | u          | u  | u         | u    | u         | u          | u   | u   | u  | u     | u    | u  | u  | u   | u          | u  |
| Bits  | 15         | 14 | 13        | 12   | 11        | 10         | 9   | 8   | 7  | 6     | 5    | 4  | 3  | 2   | 1          | 0  |
| R     | LOCK<br>UP | SW | WWD<br>T0 | SCG  | LPAC<br>K | RSTA<br>CK | DAP | PIN | 0  | FATAL | WARM | 0  | VD | POR | WAKE<br>UP |    |
| W     |            |    |           |      |           |            |     |     |    |       |      |    |    |     |            |    |
| Reset | u          | u  | u         | u    | u         | u          | u   | u   | u  | u     | u    | u  | u  | u   | u          | u  |

**Fields**

| Field       | Function                                                                                                                                                                                                  |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>—     | Reserved                                                                                                                                                                                                  |
| 30<br>—     | Reserved                                                                                                                                                                                                  |
| 29<br>—     | Reserved                                                                                                                                                                                                  |
| 28<br>JTAG  | JTAG System Reset<br>Indicates a JTAG system reset request that causes a reset.<br>This is a fatal reset source and SRAM contents are not guaranteed.<br>0b - Reset not generated<br>1b - Reset generated |
| 27<br>—     | Reserved                                                                                                                                                                                                  |
| 26<br>CDOG0 | Code Watchdog 0 Reset<br>Indicates the CDOG0 fault that causes a reset.<br>0b - Reset is not generated<br>1b - Reset is generated                                                                         |
| 25<br>—     | Reserved                                                                                                                                                                                                  |
| 24<br>—     | Reserved                                                                                                                                                                                                  |
| 23<br>—     | Reserved                                                                                                                                                                                                  |
| 22-18<br>—  | Reserved                                                                                                                                                                                                  |
| 17<br>—     | Reserved                                                                                                                                                                                                  |
| 16<br>—     | Reserved                                                                                                                                                                                                  |
| 15          | Lockup Reset                                                                                                                                                                                              |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                                                                                                                            |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LOCKUP    | Indicates the Arm core indication of a LOCKUP event that causes a reset.<br>0b - Reset not generated<br>1b - Reset generated                                                                                                                                                                        |
| 14 SW     | Software Reset<br>Indicates a software reset request from the Arm core (SYSRESETREQ) that causes a reset.<br>0b - Reset not generated<br>1b - Reset generated                                                                                                                                       |
| 13 WWDT0  | Windowed Watchdog 0 Reset<br>Indicates the WWDT 0 timeout that causes a reset.<br>0b - Reset is not generated<br>1b - Reset is generated                                                                                                                                                            |
| 12 SCG    | System Clock Generation Reset<br>Indicates a loss-of-clock or loss-of-lock event in the SCG that causes a reset.<br>This is a fatal reset source and SRAM contents are not guaranteed.<br>0b - Reset is not generated<br>1b - Reset is generated                                                    |
| 11 LPACK  | Low Power Acknowledge Timeout Reset<br>Indicates a timeout in the Low Power Mode entry logic that causes a reset. This timeout is generated if a peripheral does not acknowledge entry into Low-Power mode within 65536 cycles of clk_1M clock.<br>0b - Reset not generated<br>1b - Reset generated |
| 10 RSTACK | Reset Timeout<br>Indicates a timeout or other error condition in the system reset generation logic that causes a reset.<br>This is a fatal reset source, and SRAM contents are not guaranteed.<br>0b - Reset not generated<br>1b - Reset generated                                                  |
| 9 DAP     | Debug Access Port Reset<br>Indicates a reset request from a DAP that causes a reset.<br>0b - Reset was not generated<br>1b - Reset was generated                                                                                                                                                    |
| 8 PIN     | Pin Reset<br>Indicates an external assertion of the RESET_b pin that causes a reset.                                                                                                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                        |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 0b - Reset was not generated<br>1b - Reset was generated                                                                                                                                                        |
| 7-6<br>—    | Reserved                                                                                                                                                                                                        |
| 5<br>FATAL  | <b>Fatal Reset</b><br>Asserts if the last reset source was a fatal reset source. You cannot guarantee SRAM contents following a fatal reset source.<br>0b - Reset was not generated<br>1b - Reset was generated |
| 4<br>WARM   | <b>Warm Reset</b><br>Asserts if the last reset source was a warm reset source.<br>0b - Reset not generated<br>1b - Reset generated                                                                              |
| 3<br>—      | Reserved                                                                                                                                                                                                        |
| 2<br>VD     | <b>Voltage Detect Reset</b><br>Indicates an LVD or HVD that causes a reset.<br>0b - Reset not generated<br>1b - Reset generated                                                                                 |
| 1<br>POR    | <b>Power-on Reset</b><br>Indicates the POR detection logic that causes a reset.<br>You cannot guarantee SRAM contents following a POR source.<br>0b - Reset not generated<br>1b - Reset generated               |
| 0<br>WAKEUP | <b>Wake-up Reset</b><br>Indicates a wake-up from Deep-Power Down mode that causes a reset.<br>0b - Reset not generated<br>1b - Reset generated                                                                  |

### 18.7.1.9 Reset Pin Control (RPC)

#### Offset

| Register | Offset |
|----------|--------|
| RPC      | 84h    |

#### Function

**NOTE**

MAIN cold reset resets this register.

#### Diagram



#### Fields

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-10<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                           |
| 9<br>LPFEN  | <p>Low-Power Filter Enable</p> <p>Enables the low-power reset pin filter in both Active and Low-Power modes when this field = 1. The RESET_b pin must assert for more than three clk_1M clock cycles to always propagate through the filter. A glitch less than two clk_1M clock cycles never propagates through the filter.</p> <p>0b - Disables<br/>1b - Enables</p>                             |
| 8<br>FILTEN | <p>Filter Enable</p> <p>Enables the slow clock reset pin filter in Active modes. The RESET_b pin must assert for more than FILTCFG + 1 slow system clock cycles to always propagate through the filter. A glitch less than FILTCFG slow system clock cycles never propagates through the filter. If <b>RPC[LPFEN]</b> also becomes 1, then the filters operate in series.</p> <p>0b - Disables</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                     |
|----------------|--------------------------------------------------------------------------------------------------------------|
|                | 1b - Enables                                                                                                 |
| 7-5<br>—       | Reserved                                                                                                     |
| 4-0<br>FILTCFG | Reset Filter Configuration<br>Configures the reset pin filter's width from 1 to 32 slow system clock cycles. |

#### 18.7.1.10 Sticky System Reset Status (SSRS)

##### Offset

| Register | Offset |
|----------|--------|
| SSRS     | 88h    |

##### Function

Stores all sources of system reset that has generated a system reset since the last MAIN cold reset and that you have not cleared. SSRS does not update following a core software reset.

##### NOTE

This register resets on MAIN cold reset.

##### Diagram

| Bits  | 31         | 30  | 29    | 28   | 27    | 26         | 25  | 24  | 23  | 22    | 21   | 20  | 19  | 18  | 17         | 16  |
|-------|------------|-----|-------|------|-------|------------|-----|-----|-----|-------|------|-----|-----|-----|------------|-----|
| R     | 0          | 0   | 0     | JTAG | 0     | CDOG<br>0  | 0   | 0   | 0   | 0     | 0    | 0   | 0   | 0   | 0          | 0   |
| W     |            |     |       | W1C  |       | W1C        |     |     |     |       |      |     |     |     |            |     |
| Reset | 0          | 0   | 0     | 0    | 0     | 0          | 0   | 0   | 0   | 0     | 0    | 0   | 0   | 0   | 0          | 0   |
| Bits  | 15         | 14  | 13    | 12   | 11    | 10         | 9   | 8   | 7   | 6     | 5    | 4   | 3   | 2   | 1          | 0   |
| R     | LOCK<br>UP | SW  | WWDT0 | SCG  | LPACK | RSTA<br>CK | DAP | PIN | 0   | FATAL | WARM | 0   | VD  | POR | WAKE<br>UP |     |
| W     | W1C        | W1C | W1C   | W1C  | W1C   | W1C        | W1C | W1C | W1C | W1C   | W1C  | W1C | W1C | W1C | W1C        | W1C |
| Reset | 0          | 0   | 0     | 0    | 0     | 0          | 0   | 0   | 0   | 0     | 0    | 0   | 0   | 1   | 1          | 0   |

##### Fields

| Field | Function |
|-------|----------|
| 31    | Reserved |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                     |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —     |                                                                                                                                                                              |
| 30    | Reserved                                                                                                                                                                     |
| —     |                                                                                                                                                                              |
| 29    | Reserved                                                                                                                                                                     |
| —     |                                                                                                                                                                              |
| 28    | JTAG System Reset                                                                                                                                                            |
| JTAG  | Indicates a JTAG system reset that causes a reset.<br>This is a fatal reset source and SRAM contents are not guaranteed.<br>0b - Reset not generated<br>1b - Reset generated |
| 27    | Reserved                                                                                                                                                                     |
| —     |                                                                                                                                                                              |
| 26    | Code Watchdog 0 Reset                                                                                                                                                        |
| CDOG0 | Indicates a CDOG0 fault that causes a reset.<br>0b - Reset is not generated<br>1b - Reset is generated                                                                       |
| 25    | Reserved                                                                                                                                                                     |
| —     |                                                                                                                                                                              |
| 24    | Reserved                                                                                                                                                                     |
| —     |                                                                                                                                                                              |
| 23    | Reserved                                                                                                                                                                     |
| —     |                                                                                                                                                                              |
| 22-18 | Reserved                                                                                                                                                                     |
| —     |                                                                                                                                                                              |
| 17    | Reserved                                                                                                                                                                     |
| —     |                                                                                                                                                                              |
| 16    | Reserved                                                                                                                                                                     |
| —     |                                                                                                                                                                              |
| 15    | Lockup Reset<br>Indicates the core lockup that causes a reset.                                                                                                               |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                             |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LOCKUP       | 0b - Reset not generated<br>1b - Reset generated                                                                                                                                                                                     |
| 14<br>SW     | Software Reset<br>Indicates the software request from the Arm core (SYSRESETREQ) that causes a reset.<br>0b - Reset not generated<br>1b - Reset generated                                                                            |
| 13<br>WWDT0  | Windowed Watchdog 0 Reset<br>Indicates a windowed watchDog timeout that causes a reset.<br>0b - Reset is not generated<br>1b - Reset is generated                                                                                    |
| 12<br>SCG    | System Clock Generation Reset<br>Indicates an SCG loss of lock or loss of clock that causes a reset.<br>This is a fatal reset source and SRAM contents are not guaranteed.<br>0b - Reset is not generated<br>1b - Reset is generated |
| 11<br>LPACK  | Low Power Acknowledge Timeout Reset<br>Indicates a low power acknowledge timeout that causes a reset.<br>0b - Reset not generated<br>1b - Reset generated                                                                            |
| 10<br>RSTACK | Reset Timeout<br>Indicates a reset controller timeout that causes a reset.<br>This is a fatal reset source and SRAM contents are not guaranteed.<br>0b - Reset not generated<br>1b - Reset generated                                 |
| 9<br>DAP     | DAP Reset<br>Indicates a DAP reset request that causes a reset.<br>0b - Reset not generated<br>1b - Reset generated                                                                                                                  |
| 8<br>PIN     | Pin Reset<br>Indicates a RESET_B pin that causes a reset.<br>0b - Reset not generated                                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                  |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
|             | 1b - Reset generated                                                                                                                      |
| 7-6<br>—    | Reserved                                                                                                                                  |
| 5<br>FATAL  | Fatal Reset<br>Indicates a fatal reset source that causes a reset.<br>0b - Reset was not generated<br>1b - Reset was generated            |
| 4<br>WARM   | Warm Reset<br>Indicates a warm reset source that causes a reset.<br>0b - Reset not generated<br>1b - Reset generated                      |
| 3<br>—      | Reserved                                                                                                                                  |
| 2<br>VD     | Voltage Detect Reset<br>Indicates the LVD or HVD that causes a reset.<br>0b - Reset not generated<br>1b - Reset generated                 |
| 1<br>POR    | Power-on Reset<br>Indicates the POR that causes a reset.<br>0b - Reset not generated<br>1b - Reset generated                              |
| 0<br>WAKEUP | Wake-up Reset<br>Indicates the wake-up from Deep-Power Down mode that causes a reset.<br>0b - Reset not generated<br>1b - Reset generated |

#### 18.7.1.11 System Reset Interrupt Enable (SRIE)

Offset

| Register | Offset |
|----------|--------|
| SRIE     | 8Ch    |

## Function

Delays the assertion of a system reset for 65538 cycles of the clk\_1M clock when an interrupt is generated. This allows you to perform a graceful shutdown or to abort the warm reset provided you can clear the pending reset source by resetting the source and then clearing the pending flag. This feature cannot delay a cold or fatal warm reset source. [System Reset Status \(SRS\)](#) updates after the warm reset occurs.

The reset interrupt is not supported in Deep-Power Down mode.

### NOTE

This register is reset on MAIN Cold Reset.

## Diagram

| Bits  | 31         | 30 | 29        | 28  | 27        | 26   | 25  | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------|----|-----------|-----|-----------|------|-----|-----|----|----|----|----|----|----|----|----|
| R     |            |    |           | 0   | 0         | CDOG | 0   | 0   | 0  |    |    | 0  | 0  | 0  | 0  | 0  |
| W     |            |    |           |     |           | 0    |     |     |    |    |    |    |    |    |    |    |
| Reset | 0          | 0  | 0         | 0   | 0         | 0    | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bits  | 15         | 14 | 13        | 12  | 11        | 10   | 9   | 8   | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     | LOCK<br>UP | SW | WWDT<br>0 | SCG | LPAC<br>K | 0    | DAP | PIN |    |    |    |    | 0  |    |    |    |
| W     |            |    |           |     |           |      |     |     |    |    |    |    |    |    |    |    |
| Reset | 1          | 0  | 0         | 0   | 1         | 0    | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

## Fields

| Field | Function                                          |
|-------|---------------------------------------------------|
| 31-28 | Reserved                                          |
| —     |                                                   |
| 27    | Reserved                                          |
| —     |                                                   |
| 26    | Code Watchdog 0 Reset                             |
| CDOG0 | 0b - Interrupt disabled<br>1b - Interrupt enabled |
| 25    | Reserved                                          |
| —     |                                                   |
| 24    | Reserved                                          |
| —     |                                                   |
| 23    | Reserved                                          |
| —     |                                                   |
| 22-18 | Reserved                                          |

Table continues on the next page...

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                           |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —            |                                                                                                                                                                                    |
| 17           | Reserved                                                                                                                                                                           |
| —            |                                                                                                                                                                                    |
| 16           | Reserved                                                                                                                                                                           |
| —            |                                                                                                                                                                                    |
| 15<br>LOCKUP | Lockup Reset <p style="text-align: center;"><b>NOTE</b></p> <p>A core in the lockup state cannot service interrupts.</p> <p>0b - Interrupt disabled<br/>1b - Interrupt enabled</p> |
| 14<br>SW     | Software Reset <p>0b - Interrupt disabled<br/>1b - Interrupt enabled</p>                                                                                                           |
| 13<br>WWDT0  | Windowed Watchdog 0 Reset <p>0b - Interrupt disabled<br/>1b - Interrupt enabled</p>                                                                                                |
| 12<br>SCG    | System Clock Generation Reset <p>0b - Interrupt disabled<br/>1b - Interrupt enabled</p>                                                                                            |
| 11<br>LPACK  | Low Power Acknowledge Timeout Reset <p>0b - Interrupt disabled<br/>1b - Interrupt enabled</p>                                                                                      |
| 10<br>—      | Reserved                                                                                                                                                                           |
| 9<br>DAP     | DAP Reset <p>0b - Interrupt disabled<br/>1b - Interrupt enabled</p>                                                                                                                |
| 8<br>PIN     | Pin Reset <p>0b - Interrupt disabled<br/>1b - Interrupt enabled</p>                                                                                                                |
| 7-0          | Reserved                                                                                                                                                                           |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function |
|-------|----------|
| —     |          |

### 18.7.1.12 System Reset Interrupt Flag (SRIF)

#### Offset

| Register | Offset |
|----------|--------|
| SRIF     | 90h    |

#### Function

Returns the source of the reset interrupt. You can clear the pending reset source by resetting the source and then clearing the pending flag.

#### NOTE

This register resets on MAIN warm reset.

#### Diagram

| Bits  | 31         | 30  | 29        | 28 | 27        | 26        | 25  | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------|-----|-----------|----|-----------|-----------|-----|-----|----|----|----|----|----|----|----|----|
| R     |            |     |           | 0  | 0         | CDOG<br>0 | 0   | 0   | 0  |    |    | 0  |    | 0  | 0  | 0  |
| W     |            |     |           |    |           | W1C       |     |     |    |    |    |    |    |    |    |    |
| Reset | 0          | 0   | 0         | 0  | 0         | 0         | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bits  | 15         | 14  | 13        | 12 | 11        | 10        | 9   | 8   | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     | LOCK<br>UP | SW  | WWDT<br>0 | 0  | LPAC<br>K | 0         | DAP | PIN |    |    |    |    | 0  |    |    |    |
| W     | W1C        | W1C | W1C       |    | W1C       |           | W1C | W1C |    |    |    |    |    |    |    |    |
| Reset | 0          | 0   | 0         | 0  | 0         | 0         | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

#### Fields

| Field | Function              |
|-------|-----------------------|
| 31-28 | Reserved              |
| —     |                       |
| 27    | Reserved              |
| —     |                       |
| 26    | Code Watchdog 0 Reset |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                          |
|--------------|---------------------------------------------------------------------------------------------------|
| CDOG0        | 0b - Reset source not pending<br>1b - Reset source pending                                        |
| 25<br>—      | Reserved                                                                                          |
| 24<br>—      | Reserved                                                                                          |
| 23<br>—      | Reserved                                                                                          |
| 22-18<br>—   | Reserved                                                                                          |
| 17<br>—      | Reserved                                                                                          |
| 16<br>—      | Reserved                                                                                          |
| 15<br>LOCKUP | Lockup Reset<br>0b - Reset source not pending<br>1b - Reset source pending                        |
| 14<br>SW     | Software Reset<br>0b - Reset source not pending<br>1b - Reset source pending                      |
| 13<br>WWDT0  | Windowed Watchdog 0 Reset<br>0b - Reset source not pending<br>1b - Reset source pending           |
| 12<br>—      | Reserved                                                                                          |
| 11<br>LPACK  | Low Power Acknowledge Timeout Reset<br>0b - Reset source not pending<br>1b - Reset source pending |
| 10<br>—      | Reserved                                                                                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                |
|----------|-------------------------------------------------------------------------|
| 9<br>DAP | DAP Reset<br>0b - Reset source not pending<br>1b - Reset source pending |
| 8<br>PIN | Pin Reset<br>0b - Reset source not pending<br>1b - Reset source pending |
| 7-0<br>— | Reserved                                                                |

### 18.7.1.13 Reset Count Register (RSTCNT)

#### Offset

| Register | Offset |
|----------|--------|
| RSTCNT   | 9Ch    |

#### Function

The Reset Count Register returns the number of reset sequences completed since the last MAIN Cold Reset.

#### NOTE

This register is reset on MAIN Cold Reset.

#### Diagram



**Fields**

| Field        | Function                                                                                                                                                         |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8<br>—    | Reserved                                                                                                                                                         |
| 7-0<br>COUNT | Count<br>Number of reset sequences completed since the last MAIN Cold Reset. When the count reaches the maximum value, it will saturate and no longer increment. |

**18.7.1.14 Mode (MR0)****Offset**

| Register | Offset |
|----------|--------|
| MR0      | A0h    |

**Function**

Contains the state of the boot mode pins sampled at the end of the reset.

**NOTE**

This register resets on MAIN warm reset, and the reset value may vary depending on the pin state.

**Diagram****Fields**

| Field          | Function                                                                                                            |
|----------------|---------------------------------------------------------------------------------------------------------------------|
| 31-1<br>—      | Reserved                                                                                                            |
| 0<br>ISPMODE_n | In System Programming Mode<br>Returns the logic state of the ISPMODE_n pin on the last negation of the RESET_b pin. |

### 18.7.1.15 Force Mode (FM0)

#### Offset

| Register | Offset |
|----------|--------|
| FM0      | B0h    |

#### Function

Contains registers that override the state of the boot mode pins.

#### NOTE

This register resets on MAIN cold reset.

#### Diagram

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

#### Fields

| Field         | Function                                                                                                                                             |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-1<br>—     | Reserved                                                                                                                                             |
| 0<br>FORCECFG | Boot Configuration<br>Forces the corresponding field in <a href="#">Mode (MR0)</a> to assert on next system reset.<br>0b - No effect<br>1b - Asserts |

### 18.7.1.16 Flash Control (FLASHCR)

#### Offset

| Register | Offset |
|----------|--------|
| FLASHCR  | E0h    |

**Function**

Controls Low-Power mode of the on-chip flash memory.

**NOTE**

This register resets on MAIN warm reset.

**Diagram**

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19    | 18    | 17    | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|-------|-------|-------|----|
| R     |    |    |    |    |    |    |    |    | 0  |    |    |    |       |       |       |    |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |       |       |       |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0     | 0     | 0  |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3     | 2     | 1     | 0  |
| R     |    |    |    |    |    |    |    |    | 0  |    |    |    | FLASH | FLASH | FLASH |    |
| W     |    |    |    |    |    |    |    |    |    |    |    |    | WA... | DO... | DIS   |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0     | 0     | 0  |

**Fields**

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2<br>FLASHWAKE | <p><b>Flash Wake</b></p> <p>Specifies that when this field becomes 1, an attempt to access the flash memory when it is in Low-Power state because of <a href="#">FLASHCR[FLASHDIS]</a> or <a href="#">FLASHCR[FLASHDOZE]</a>, causes the flash memory to exit Low-Power state for the duration of the flash memory access.</p> <p>0b - No effect<br/>1b - Flash memory is not disabled during flash memory accesses</p>                                   |
| 1<br>FLASHDOZE | <p><b>Flash Doze</b></p> <p>Disables flash memory accesses and places flash memory in Low-Power state whenever the core clock is gated (<math>\text{CKMODE} &gt; 0</math>) because of execution of WFI, WFE, or SLEEPONEXIT. Other bus masters that attempt to access the flash memory stalls until the core is no longer sleeping.</p> <p>0b - No effect<br/>1b - Flash memory is disabled when core is sleeping (<math>\text{CKMODE} &gt; 0</math>)</p> |
| 0<br>FLASHDIS  | <p><b>Flash Disable</b></p> <p>Places flash memory in Low-Power state when this field becomes 1. Relocate the interrupts out of flash memory before disabling it.</p> <p>0b - No effect<br/>1b - Flash memory is disabled</p>                                                                                                                                                                                                                             |

### 18.7.1.17 Core Control (CORECTL)

#### Offset

| Register | Offset |
|----------|--------|
| CORECTL  | 110h   |

#### Function

Configures options for the core.

##### NOTE

This register resets on MAIN warm reset.

#### Diagram



#### Fields

| Field     | Function                                                                                                                                                                               |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-1<br>— | Reserved                                                                                                                                                                               |
| 0<br>NPIE | <p>Non-maskable Pin Interrupt Enable</p> <p>Enables or disables the pin interrupt.</p> <p>You can write to this field only when NPIE = 0.</p> <p>0b - Disables</p> <p>1b - Enables</p> |

### 18.7.1.18 Debug Control (DBGCTL)

#### Offset

| Register | Offset |
|----------|--------|
| DBGCTL   | 120h   |

#### Function

Configures options for debug.

**NOTE**

This register resets on MAIN cold reset.

#### Diagram



#### Fields

| Field     | Function                                                                                                                                     |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31-1<br>— | Reserved                                                                                                                                     |
| 0<br>SOD  | <p>Sleep Or Debug</p> <p>Configures whether the debug remains enabled when core sleeps.</p> <p>0b - Remains enabled</p> <p>1b - Disabled</p> |

# Chapter 19

## Reset

### 19.1 Reset sources

The following reset sources exist in this chip:

Table 92. Reset sources

| Reset source | Description                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Power        | System Power-On Reset (POR)                                                                                                                                                                                                                                                                                                                                                                  |
|              | System Low-Voltage Detect (LVD)                                                                                                                                                                                                                                                                                                                                                              |
|              | System High-Voltage Detect (HVD)                                                                                                                                                                                                                                                                                                                                                             |
| External     | Wake Up Unit (WUU)                                                                                                                                                                                                                                                                                                                                                                           |
|              | External pin reset (RESET_b)                                                                                                                                                                                                                                                                                                                                                                 |
| Internal     | <ul style="list-style-type: none"> <li>• Code Watchdog reset</li> <li>• Watchdog (WDOG) reset</li> <li>• Software (SW) reset</li> <li>• System Clock Generator (SCG-lite) Loss of Clock</li> <li>• Reset Acknowledge timeout (RSTACK)</li> <li>• Low Power Acknowledge (LPACK)</li> <li>• Core Lockup (LOCKUP)</li> <li>• Debug Mailbox</li> <li>• Joint Test Action Group (JTAG)</li> </ul> |

Each system reset source has a corresponding bit that is maintained in the System Reset Status register through reset. This information can be used to take appropriate action when coming out of a reset.

### 19.2 Power reset sources

To ensure predictable operation of the chip, the supply voltages must remain in their specified ranges during execution. Because this is not possible during power-up and power-down, the chip implements multiple voltage monitors to detect when the supply is outside an acceptable range. When this occurs, the voltage monitor asserts a reset to halt execution and prevent unexpected behavior. The voltage monitors detect power-on events as well as low and high voltage events.

#### 19.2.1 POR Reset

The VDD\_SYS domain implements a “POR Only Reset (POR)” which only asserts on VDD\_SYS analog POR. This reset source is only used for resetting the registers used by the LVD/HVD detectors. The POR voltage monitor is used to ensure that the voltage applied to the system is high enough for other analog modules such as the bias circuits and low voltage monitors to operate correctly. When voltage is initially applied to the chip or when the supply voltage drops below the POR falling threshold, the POR monitor triggers the POR reset condition to the chip.

The POR reset condition asserts POR reset to all power domains. A POR reset sets the appropriate bits in the CMC registers so that software can determine that a POR reset has occurred. See [Block diagram](#).

### 19.2.2 Low-Voltage Detect (LVD)

The LVD monitors are used to ensure that the voltage supplies to the device are high enough for the logic and memories using those power supplies to operate correctly. When voltage is initially applied to the device, the POR voltage monitor holds the LVD monitors in reset until the voltages are high enough. The LVD monitors continue to hold the device in reset until all monitoring voltages have risen above the respective default LVD Low thresholds (VLVDL). The LVD monitor is enabled by default.

When enabled, the LVD monitor generates a reset when the voltage drops below the  $V_{LVD}$  threshold. The voltage threshold at which the LVD reset asserts is programmable. This ensures that the chip halts operation and remains in reset while the monitored voltage is not within the desired range.

The LVD monitors are available in the Active, Sleep, and Deep Sleep modes and are disabled in Deep Power Down modes. See [Module operation in low power modes](#) for the available modes.

The individual LVD monitor resets are combined into a single LVD reset trigger to the Core Mode Controller (CMC). The LVD reset condition asserts a reset to all power domains with only the POR/LVD/HVD detection logic remaining operational. A LVD reset will set the appropriate bits in the CMC registers so that software can determine that a LVD reset has occurred.

### 19.2.3 High-Voltage Detect (HVD)

The HVD monitors are used to ensure that the voltage supplies to the device are within operation range for the logic and memories using those power supplies. The HVD monitor is disabled by default, but when the HVD circuit is enabled, the HVD monitor will generate a reset when the voltage rises above the VHVDL threshold. The voltage threshold at which the HVD reset asserts is programmable. This ensures that the device halts operation and remains in reset while the monitored voltage is not within the desired range.

The HVD monitors are available in the Active, Sleep, and Deep Sleep modes. The HVD monitors are disabled in Deep Power Down modes.

The individual HVD monitor resets are combined into a single HVD reset trigger to the Core Mode Controller (CMC). The HVD reset condition asserts a reset to all power domains with only the POR/LVD/HVD detection logic remaining operational. A HVD reset is combined with LVD reset, and will set the appropriate bits in the CMC registers so that software can determine that a HVD reset has occurred.

## 19.3 External reset sources

External resets are provided so that the chip can be reset or wake up from very low power states. This allows the chip to start at the correct time from a known state.

### 19.3.1 External pin reset (RESET\_b)

The RESET\_b pin is a bi-directional open-drain pin with internal pull-up resistor. The RESET\_b pin is functional in two modes:

- During active and low power modes, the RESET\_b pin can be asserted externally to force the chip into Pin reset condition.
- During reset, the RESET\_b drives low until the chip has completed hardware initialization, at which point the RESET\_b pin is released. If the RESET\_b pin is asserted externally, then the chip will remain in reset until the RESET\_b input is pulled high.

The RESET\_b pin implements a digital filter that software can configure to filter out glitches on the RESET\_b pin that are less than 1-32 CMC clock cycles. The filter is bypassed in low power modes when the CMC clock is disabled.

The RESET\_b is multiplexed on P1\_29 pin on this device. RESET\_b is the default function of this GPIO pin. Asserting RESET\_b wakes the device from any mode.

The PIN reset condition triggers the CMC to assert a Warm reset to all power domains. A Pin reset sets the appropriate fields in the CMC registers so that software can determine that a Pin reset has occurred.

### 19.3.2 Wake-up (WAKEUP)

The Wake-Up Unit (WUU) provides for a number of external pins and on-chip peripherals to wake the chip from Deep Power Down mode. See the [WUU](#) chapter for a list of external and internal reset sources connected to the WUU.

On a wakeup from Deep Power Down mode, the power management logic triggers a WAKEUP reset in the power domains that had been powered off.

The WAKEUP reset condition triggers the CMC to assert a POR reset to the power domains that were powered down. The system voltage domain is not affected by a WAKEUP reset. A WAKEUP reset sets the appropriate fields in the CMC registers so that software can determine that a WAKEUP reset has occurred.

## 19.4 Internal reset sources

Internal resets are provided so that the device can be reset when certain erroneous conditions are detected. This allows the device to recover from the erroneous conditions and restart from a known state.

### 19.4.1 Code Watchdog reset

The Code Watchdog Timer (CDOG) module helps protect the integrity of software by detecting unexpected changes (faults) in code execution flow. The CDOG module can be configured to reset or interrupt the processor core when the module detects a fault.

The CDOG reset condition triggers the Core Mode Controller (CMC) to assert a WARM reset to all power domains. A CDOG reset sets the appropriate bits in the CMC registers so that software can determine that a WDOG reset has occurred.

### 19.4.2 Windowed Watchdog timer (WDOG) reset

The WDOG reset is generated by the WWDT module on the chip.

The WWDT monitors the operation of the system by receiving periodic communication from the software. This communication is generally known as servicing or refreshing the WDOG. If this periodic servicing does not occur, then the Watchdog triggers a WDOG reset condition.

The WDOG reset condition triggers the CMC to assert a WARM reset to all power domains. A WDOG reset sets the appropriate fields in the CMC registers so that software can determine that a WDOG reset has occurred.

### 19.4.3 Software (SW) reset

During execution, if the software detects erroneous operation, the software can initiate a reset to restart the chip from a known state.

The SW reset condition, which is generated by SYSRESETREQ, triggers the CMC to assert a WARM reset to all power domains. A SW reset sets the appropriate fields in the CMC registers so that software can determine that a SW reset has occurred. For details, refer System Reset Status Register (SRS) in the [CMC](#) chapter.

### 19.4.4 System Clock Generation (SCG)

The SCG module contains a clock monitor, which, if enabled, detects a loss of the external clock. A loss of external clock triggers the SCG reset condition.

The SCG reset condition asserts a WARM reset in all power domains. The CMC\_SRS[SCG] and CMC\_SRS[WARM] status bits are set on a SCG reset condition.

For details on enabling the clock monitor, see the [SCG](#) chapter. To prevent unexpected reset events, clock monitors must be disabled before entering any low-power modes that the external clocks are not present.

### 19.4.5 Reset Acknowledge timeout (RSTACK)

The reset state machine includes a timeout counter that is triggered by the reset state machine not progressing within 65536 cycles of the clk\_1m clock, which triggers the RSTACK reset condition.

The RSTACK reset condition triggers the CMC to assert a WARM reset to all power domains. An RSTACK reset sets the appropriate fields in the CMC registers so that software can determine that an RSTACK reset has occurred.

#### 19.4.6 Low Power Acknowledge timeout (LPACK)

The low power entry state machine includes a timeout counter that is triggered if a module does not acknowledge entry into a low power mode after 65536 cycles of the clk\_1m clock; this triggers the LPACK reset condition.

The LPACK reset condition triggers the CMC to assert a WARM reset to all power domains. An LPACK reset sets the appropriate fields in the CMC registers so that software can determine that an LPACK reset has occurred.

#### 19.4.7 Lock up (LOCKUP)

The Cortex-M33 core enters the lockup state as a result of certain illegal operations, which triggers the LOCKUP reset condition.

The LOCKUP reset condition triggers the CMC to assert a WARM reset to all power domains. A LOCKUP reset sets the appropriate fields in the CMC registers so that software can determine that a LOCKUP reset has occurred.

#### 19.4.8 Debug Mailbox (DM)

Debug Mailbox (ISP-AP) can initiate a reset request from a connected debugger. This triggers the debug mailbox reset condition.

The DM reset condition triggers the CMC to assert a WARM reset to all power domains. A DM reset sets the appropriate fields in the CMC registers so that software can determine that a DM reset has occurred.

#### 19.4.9 JTAG

Whenever a JTAG instruction places the chip in reset, it triggers the JTAG reset condition.

The JTAG reset condition triggers the CMC to assert a WARM reset to all power domains. A JTAG reset sets the appropriate bits in the CMC registers so that software can determine that a JTAG reset has occurred.

### 19.5 Reset type

This section describes the different resets that can be generated on this chip and their respective reset sequences. Reset conditions on this chip are categorized into two types, Cold and Warm resets.

#### 19.5.1 Cold reset

A cold reset is a reset that only asserts when a power domain is powered up (Power On Reset, Power Down wakeup, etc) or one of the supply voltages is not valid (LVD, HVD, supply glitch detect). For simplicity, all LVD/HVD assert the Cold Reset for all power domains. Each power domain has its own "Cold Reset" which is used by any logic in that domain that needs a reset that does not assert on a warm reset source. The VDD\_SYS domain also implements a "POR Only Reset" which only asserts on VDD\_SYS analog POR. This reset source is only used for resetting the registers used by the LVD/HVD detectors. A POR does not guarantee the contents of on-chip SRAM, except for a Deep Power Down wakeup and then only for the SRAM that is configured to retain state.

##### 19.5.1.1 POR reset sequence

The following steps are performed as part of the POR (or LVD/HVD) sequence:

1. RESET\_b pin is driven low and internal reset signals assert.
2. POR and LVD signals negate and clocks are enabled in their default configuration.
3. Internal reset remains asserted for 32 CM33 clock cycles.
4. Internal reset to Flash and Fuse controller negate and their initialization sequences commence.
5. Initialization sequences for Flash and Fuse complete.
6. Internal trim registers are loaded and RESET\_b pin is tri-stated.
7. Reset state machine waits for RESET\_b pin input to pull high or drive high externally.
8. Internal reset signals negate.

9. Core exits reset and fetches the initial program counter and stack pointer from Boot ROM.

When the chip wakes up from Deep Power Down, the reset sequence is slightly different from the POR reset sequence. They are described in the subsequent sections.

### 19.5.1.2 Deep Power Down (DPD) reset sequence

The following steps are performed as part of the Deep Power Down wakeup sequence:

1. Internal reset signals assert.
2. Wakeup signal negates and clocks are enabled in their default configuration.
3. Internal reset remains asserted for 32 clock cycles.
4. Internal reset to Flash and Fuse controller negate and their initialization sequences commence.
5. Initialization sequences for Flash and Fuse complete.
6. Internal trim registers are loaded.
7. Internal reset signals negate.
8. Core exits reset and fetches the initial program counter and stack pointer from Boot ROM.

The RESET\_b pin is not driven low by a Deep Power Down reset sequence unless the RESET\_b pin was used as the wake up source.

A wakeup from Deep Power Down via the RESET\_b pin will follow the warm reset sequence.

### 19.5.2 Warm reset

A warm reset is a reset that asserts on either:

- Cold Reset for that power down
- Any of the warm reset sources

Any of the warm reset sources will trigger a warm reset for every power domain. An “early” warm reset is generated for some of the power domain, this reset asserts at the same time as the normal reset but negates early to allow processes that need to operate during reset to complete. This includes the MSF loading of IFR trim data.

A WARM reset re-initializes the chip to a known state once it has already been running for a period of time.

A WARM reset resets most of the logic in each power domain. Warm resets are divided into fatal reset sources and non-fatal reset sources. See the following table to know which CMC reset sources are fatal/non-fatal. Also see [CMC chapter](#) for details..

| CMC reset source         | Fatal Reset |
|--------------------------|-------------|
| Reset pin                | N           |
| Debug AP (debug mailbox) | N           |
| Reset Monitor            | Y           |
| Low Power Monitor        | N           |
| Loss of Clock / Lock     | N           |
| WDOG0 reset              | N           |
| CM33 reset request       | N           |
| CM33 lockup              | N           |
| Code WDG0 reset          | N           |

*Table continues on the next page...*

*Table continued from the previous page...*

| CMC reset source         | Fatal Reset |
|--------------------------|-------------|
| JTAG boundary scan reset | Y           |

Non-fatal reset sources can be configured to generate an interrupt instead of the WARM reset. If software can clear the non-fatal reset source (including status flag) within 64 ms then the WARM reset is averted. Non-fatal resets retain the contents of on-chip SRAM.

Fatal reset sources cannot be configured to generate an interrupt, and do not guarantee the contents of on-chip SRAM.

The following steps are performed as part of the warm reset sequence:

1. RESET\_b pin drives low and internal reset signals assert.
2. Clocks are enabled in their default configuration.
3. Internal reset remains asserted for 32 clock cycles.
4. Internal reset to Flash and Fuse controller negate and their initialization sequences commence.
5. Initialization sequences for Flash and Fuse complete.
6. Internal trim registers are loaded and RESET\_b pin is tri-stated.
7. Reset state machine waits for RESET\_b pin input to pull high or drive high externally.
8. Internal reset signals negate.

Core exits reset and fetches the initial program counter and stack pointer from Boot ROM.

### 19.5.3 Peripheral SW reset

Peripherals can be reset by SW. The chip implements Peripheral reset control registers in the System Controller (SYSCON) chapter.

# Chapter 20

## Boot ROM

### 20.1 MCXA1 Boot ROM

### 20.2 Boot ROM

This chapter defines the structure and flow of the MCXA1 boot ROM and its interaction with the extended bootloader on IFR0.

#### 20.2.1 Overview

On this chip, ROM only supports on-chip Flash image boot with no external memory boot.

On this device, there are two software, one software is boot ROM, located on ROM memory and the second software is called extended bootloader, which located on IFR0, sector 1-3.

**Table 93. MCXA1 on chip software**

| Term                           | Definition                                                                                                                                                                                  |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Boot ROM (software)            | In the context of this document, Boot ROM is the piece of software present in ROM memory implementing features explained throughout this document.                                          |
| Extended Bootloader (Software) | In the context of this document, Extended Bootloader is the piece of software present in IFR0 memory implementing features explained throughout this document.<br>IFR0 sector 1 ~ 3 (24 KB) |

ROM working with extended bootloader takes responsibility for boot flow.

Boot related parameters are in Customer Manufacturing/Factory Programming Area (CMPA), and ROM uses some settings on this field to update the booting options.

#### 20.2.2 Features

The main features of the Boot ROM (16 KB) and extended bootloader (24 KB) include:

- Checks life cycle, set Read Out Protection (ROP).
- Enables/disables debug port per lifecycle.
- Sets ROM hidden per lifecycle.
- Handles debug mailbox commands, but available commands sets are per lifecycle.
- Handles ISP (In-System Programming) commands, but available commands sets are per lifecycle.
- Provides Flash API
- Supports Flash swap
- Only supports ISP boot; does not support master boot

#### 20.2.3 Function description

### 20.2.3.1 Software block diagram



Figure 27. Software flow figure

### 20.2.3.2 ROM component

After any reset, including POR reset and warm reset sequence, CPU always runs to boot ROM. The main functions of ROM are:

- Check life cycle,
- Process mailbox request through debug access port
- Configure the GLIKEY and MBC
- Run image integrity check based on wakeup source
- Before exit to extended bootloader (on IFR0), hides critical sections
- ROM provides flash driver API to the user.

ROM memory starts from 0x0300\_0000; ROM size is 16 KB.



Figure 28. ROM memory

**Figure 29. RAM memory**

### 20.2.3.3 Extended bootloader component

Extended bootloader is the secondary bootloader, which is located in IFR0, sector 1 ~ 3, total 24 KB. It checks the configuration, enables the booting interfaces, performs ISP command following NXP bootloader protocol, and others tasks. See [Extended Bootloader and In-System programming \(ISP\)](#) for more details.

Due to limited IFR0 memory size, there are two extended bootloader releases to be programmed to IFR0.

- Supports USB and LPUART booting peripherals

NXP programs one of them to IFR0, as per the required configuration, or customer request.



### 20.2.3.4 User image header

| Offset | Size in bytes | Symbol       | Description                                 |
|--------|---------------|--------------|---------------------------------------------|
| 0x00   | 4             | Initial SP   | Stack pointer                               |
| 0x04   | 4             | Initial PC   | The application first execution instruction |
| 0x08   | 24            | Vector table | Cortex-M33 Vector table entries             |
| 0x20   | 4             | Image length | The length of the current image             |
| 0x24   | 4             | Image type   | Image Type: Bit [7:0]:                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset | Size in bytes | Symbol                 | Description                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|---------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |               |                        | <ul style="list-style-type: none"> <li>• 0x0: plain image</li> <li>• 0x2: plain image with CRC</li> <li>• 0x5: plain image with CRC</li> </ul> Bit[10] – Image version included in Image Type <ul style="list-style-type: none"> <li>• 0: Image version is not in the Image Type</li> <li>• 1: Image version is not in the Image Type</li> </ul> Bit[31:16] – Image version (for on-chip flash) when bit[10] is set |
| 0x28   | 4             | offsetToExtendedHeader | Offset to extended header. For a signed image (Image Type = 0x04), this is offset to the certificate header block.<br>For a CRC image (Image Type = 0x2 or 0x5), this is the CRC checksum value                                                                                                                                                                                                                     |
| 0x2C   | 8             | Vector table           | Cortex-M33 Vector table entries                                                                                                                                                                                                                                                                                                                                                                                     |
| 0x34   | 4             | ImageExecutionAddress  | The execution address of the image <ul style="list-style-type: none"> <li>• Set 0 if image type is XIP.</li> <li>• Set to actual image execution address if the image type is load to RAM.</li> </ul>                                                                                                                                                                                                               |
| 0x38   |               | Vector table           | Cortex-M33 Vector table entries                                                                                                                                                                                                                                                                                                                                                                                     |

## 20.2.4 Boot pins

The table below shows the ISP pin assignments and is the default assignment used by extend bootloader. However they can be changed in the CMPA settings. For more details, see the attached IFR map spreadsheet.

Table 94. ROM pin assignments

| ISP pin        | Port pin assignment |
|----------------|---------------------|
| ISPMODE_N      | P3_29               |
| LPUART ISP pin |                     |
| LPUART, RX     | P0_2                |
| LPUART, TX     | P0_3                |

*Table continues on the next page...*

**Table 94. ROM pin assignments (continued)**

| ISP pin         | Port pin assignment |
|-----------------|---------------------|
| USB FS ISP mode |                     |
| USB0_DM         |                     |
| USB0_DP         |                     |
| USB0_VBUS_DET   | P2_12               |

### 20.2.5 Top-level boot flow

The below chart shows the top-level boot flow. The device always starts ROM after reset.

- By default, ROM runs at 48 MHz
- ROM checks if there is valid extended bootloader on IFR0 (sector1 ~ sector3) by using CRC32. For power reset, it runs full image CRC32 check, and for Deep Power Down wake up, it only runs partial CRC32 check.  
If extended bootloader is valid, ROM jumps to extended bootloader
- Extended bootloader runs to normal boot or ISP boot, depending on ISP\_Mode pin or CMAP setting.
- Extended bootloader runs user image validity check. It also runs CRC32 if CRC check is present in the image header.



Figure 30. Top level boot flow





### 20.2.6 ISP Boot mode

Depending on the values of ISP mode in the CMPA and ISP pin, bootloader decides whether to enter normal boot flow, or enter ISP mode.

Table 95. ISP mode based on ISP\_BOOT\_IF CMPA bit field (word0[6:4])

| ISP boot interface | CMPA field value | Description                                                                                                                                                               |
|--------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Auto ISP           | 3'b000           | Bootloader probes the active peripheral form ton the below serial interfaces to download image:<br>LPUART and USB0.<br>(however it depends on extended bootloader choice) |
| UART ISP           | 3'b001           | LPUART is used to download the image                                                                                                                                      |
| USB0 HID           | 3'100            | USB0 is used to download the image                                                                                                                                        |
| USB1 HID           | 3'101            | NA                                                                                                                                                                        |
| CAN ISP            | 3'110            | NA                                                                                                                                                                        |
| Reserved           | 3'111            |                                                                                                                                                                           |

### 20.2.7 CMPA configuration options

| CMPA Field       | Offset | Bit     | Description                                                                                                                                                           |
|------------------|--------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Header           | 0      | [31:15] | CMPA header marker,<br>16'h5963                                                                                                                                       |
| BOOT_SPEED       | 0      | [13:12] | Core clock, default 48MHz <ul style="list-style-type: none"> <li>• 00 - 48MHz FRO @1v0</li> <li>• 01 - 96MHz FRO @1v1</li> </ul>                                      |
| ISP_BOOT_IF      | 0      | [6:4]   | ISP boot interface: <ul style="list-style-type: none"> <li>• 001 - UART ISP</li> <li>• 100 - USB0_HID</li> <li>• Others – Reserved</li> </ul>                         |
| ISP_DM_ENTRY     | 4      | [31:12] | Disable ISP mode entry through debug mailbox command.                                                                                                                 |
| ISP_PIN_ENTRY    | 4      | [11:10] | Disable ISP mode entry through pin assertion. <ul style="list-style-type: none"> <li>• 01 - ISP entry disabled</li> <li>• 00, 10, 11 - ISP entry allowed..</li> </ul> |
| FLASH_REMAP_SIZE | 4      | [4:0]   | Flash remap size. This field should be written to remap field in flash.                                                                                               |

Table continues on the next page...

*Table continued from the previous page...*

| CMPA Field                         | Offset | Bit     | Description                                                                                                                                                                                                                                                                                                                                                               |
|------------------------------------|--------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BOOT_FAIL_LED                      | 8      | [23:16] | <p>Assert on fatal errors during boot. ROM toggles the GPIO pin identified by this field whenever primary boot fails due to fatal errors before locking-up/reset.</p> <p>— NOTE —</p> <p>Use QUICK_SET_/_CLR_GPIOx field to set the default level of pin.</p> <ul style="list-style-type: none"> <li>• [4:0] GPIO Pin number</li> <li>• [7:5] GPIO port number</li> </ul> |
| POWERDOWN_TIMEOUT_SECS             | 0x0c   | [15:0]  | Power down timeout: Timeout value in seconds. When a non-zero value is programmed in this field, ROM uses it as idle timeout value to enter power-down state to conserve power                                                                                                                                                                                            |
| ISP_UART_CFG:<br>UART_BAUD_RATE    | 0x10   | [31:28] | Baud rate configured during UART ISP mode. <ul style="list-style-type: none"> <li>• 0000 - Auto baud detection.</li> <li>• default: Auto baud detection.</li> </ul>                                                                                                                                                                                                       |
| ISP_UART_CFG:<br>UART_TX_FUNC_SLOT | 0x10   | [27:24] | Identifies the pin mux function slot.                                                                                                                                                                                                                                                                                                                                     |
| ISP_UART_CFG:<br>UART_TX_PIN       | 0x10   | [23:16] | Override default UART TX ISP pin. Identifies the pin to be used as UART_TX pin. <ul style="list-style-type: none"> <li>• [4:0] GPIO Pin number</li> <li>• [7:5] GPIO port number</li> </ul>                                                                                                                                                                               |

*Table continues on the next page...*

*Table continued from the previous page...*

| CMPA Field                         | Offset | Bit     | Description                                                                                                                                                                                                                                |
|------------------------------------|--------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ISP_UART_CFG:<br>UART_ISP_INSTANCE | 0x10   | [15:12] | Identifies the LPUART instance used for UART ISP mode.                                                                                                                                                                                     |
| ISP_UART_CFG:<br>UART_RX_FUNC_SLOT | 0x10   | [11:8]  | Identifies the pin mux function slot.                                                                                                                                                                                                      |
| ISP_UART_CFG:<br>UART_RX_PIN       | 0x10   | [7:0]   | Override default UART RX ISP pin. Identifies the pin to be used as UART_RX pin. <ul style="list-style-type: none"> <li>• [4:0] GPIO Pin number</li> <li>• [7:5] GPIO port number</li> </ul>                                                |
| USB Product ID                     | 0x24   | [31:16] | USB Product ID                                                                                                                                                                                                                             |
| USB Vendor ID                      | 0x24   | [15:0]  | USB Vendor ID                                                                                                                                                                                                                              |
| USBx_VBUS_FUNC_SLOT                | 0x28   | [11:8]  | Identifies the pin mux function slot.                                                                                                                                                                                                      |
| USBx_VBUS_PIN                      | 0x28   | [7:0]   | Override default USB0_VBUS_DETECT ISP pin. Identifies the pin to be used as USB0_VBUS detect pin. <ul style="list-style-type: none"> <li>• [4:0] GPIO Pin number</li> <li>• [7:5] GPIO port number</li> </ul>                              |
| ISP_MISC_CFG:<br>ISP_UART_CUST     | 0x2C   | [31:30] | Use customer defined UART ISP pins. <ul style="list-style-type: none"> <li>• 01: Customer defined.</li> <li>• 00, 10, 11: Default ROM defined pins.</li> </ul>                                                                             |
| ISP_MISC_CFG:<br>ISP_USB_CUST      | 0x2C   | [23:22] | Use customer defined GPIO for USB VBUS detect function during ISP mode. <ul style="list-style-type: none"> <li>• 00: Use dedicated VBUS pins.</li> <li>• 01: Customer defined GPIO for USB0_VBUS detect</li> <li>• 10: Reserved</li> </ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| CMPA Field                    | Offset | Bit     | Description                                                                                                                                                                                                      |
|-------------------------------|--------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                               |        |         | <ul style="list-style-type: none"> <li>• 11: Use VDD_USB for VBUS presence. On board regulator should generate VDD_USB voltage using 5V input for VBUS pin on connector. .</li> </ul>                            |
| FLASH_ACL_0_7:<br>ACL_SEC_7   | 0x40   | [30:28] | Access control for flash sector Select one of the 8 pre-defined access control attributes for the given sector. Access attributes control read, write, execute and lock access along with sticky lock protection |
| FLASH_ACL_0_7:<br>ACL_SEC_6   |        | [26:24] | Please refer to MBC chapter and also check the flash granularity                                                                                                                                                 |
| FLASH_ACL_0_7:<br>ACL_SEC_5   |        | [22:20] |                                                                                                                                                                                                                  |
| FLASH_ACL_0_7:<br>ACL_SEC_4   |        | [18:16] |                                                                                                                                                                                                                  |
| FLASH_ACL_0_7:<br>ACL_SEC_3   |        | [14:12] |                                                                                                                                                                                                                  |
| FLASH_ACL_0_7:<br>ACL_SEC_2   |        | [10:8]  |                                                                                                                                                                                                                  |
| FLASH_ACL_0_7:<br>ACL_SEC_1   |        | [6:4]   |                                                                                                                                                                                                                  |
| FLASH_ACL_0_7:<br>ACL_SEC_5   |        | [3:0]   |                                                                                                                                                                                                                  |
| FLASH_ACL_15_8:<br>ACL_SEC_15 | 0x44   | [30:28] |                                                                                                                                                                                                                  |
| FLASH_ACL_15_8:<br>ACL_SEC_14 |        | [26:24] |                                                                                                                                                                                                                  |
| FLASH_ACL_15_8:<br>ACL_SEC_13 |        | [22:20] |                                                                                                                                                                                                                  |
| FLASH_ACL_15_8:<br>ACL_SEC_12 |        | [18:16] |                                                                                                                                                                                                                  |
| FLASH_ACL_15_8:<br>ACL_SEC_11 |        | [14:12] |                                                                                                                                                                                                                  |
| FLASH_ACL_15_8:<br>ACL_SEC_10 |        | [10:8]  |                                                                                                                                                                                                                  |
| FLASH_ACL_15_8:<br>ACL_SEC_9  |        | [6:4]   |                                                                                                                                                                                                                  |
| FLASH_ACL_15_8:<br>ACL_SEC_8  |        |         | [3:0]                                                                                                                                                                                                            |

*Table continues on the next page...*

*Table continued from the previous page...*

| CMPA Field                  | Offset | Bit    | Description                                                                                                                                                                                                                                                                                                                        |
|-----------------------------|--------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| QUICK_SET_GPIO_0            | 0x60   | [31:0] | Drive GPIO 0 port pins high after reset. Each bit corresponds to the pin in GPIO port 0. When set, ROM drives the corresponding pin high as soon as possible. By default most pins come-up as tri-stated inputs. This feature allows customer to specify active drive pins soon after reset instead of waiting till complete boot. |
| QUICK_CLR_GPIO_0            | 0x64   | [31:0] | Drive GPIO $n$ port pins low. See description of QUICK_SET_GPIO_ $n$ field.                                                                                                                                                                                                                                                        |
| QUICK_SET_GPIO_1            | 0x68   | [31:0] |                                                                                                                                                                                                                                                                                                                                    |
| QUICK_CLR_GPIO_1            | 0x6C   | [31:0] |                                                                                                                                                                                                                                                                                                                                    |
| QUICK_SET_GPIO_2            | 0x70   | [31:0] |                                                                                                                                                                                                                                                                                                                                    |
| QUICK_CLR_GPIO_2            | 0x74   | [31:0] |                                                                                                                                                                                                                                                                                                                                    |
| QUICK_SET_GPIO_3            | 0x78   | [31:0] |                                                                                                                                                                                                                                                                                                                                    |
| QUICK_CLR_GPIO_3            | 0x7C   | [31:0] |                                                                                                                                                                                                                                                                                                                                    |
| ROP_STATE                   | 0x90   | [31:0] |                                                                                                                                                                                                                                                                                                                                    |
| ROP_STATE_DP<br>(Duplicate) | 0xA0   | [31:0] |                                                                                                                                                                                                                                                                                                                                    |

- Supports USB and LPUART booting peripherals. CMPA ISP\_BOOT\_IF field setting choices are:
  - 000 - Auto ISP, USB, and UART
  - 001 - UART ISP
  - 100 - USB0\_HID
  - Others - Reserved

### 20.2.8 ROM API

ROM bootloader provides APIs for users. Disabling the interrupts before making any ROM API calls is suggested, since API does not handle any interrupts.

The struct of bootloader\_tree:

```

///! @brief Root of the bootloader API tree.
///
///! An instance of this struct resides in read-only memory in the bootloader. It
///! provides a user application access to APIs exported by the bootloader.
///
///! @note The order of existing fields must not be changed.
///
///! @ingroup context
typedef struct BootloaderTree
{
    void (*runBootloader)(void *arg);           ///< Function to start the bootloader executing.
    const flash_driver_interface_t *flashDriver; //!!< Internal Flash driver API.
} bootloader_tree_t;

```

The ROM API table locates at address (0x03003fe0u)

```

#define BOOTLOADER_TREE_LOCATION (0x03003fe0u)
#define g_bootloaderTree ((bootloader_tree_t *)BOOTLOADER_TREE_LOCATION)

```

#### 20.2.8.1 runBootloader API

ROM provides an API for the user application to enter ISP mode based on the designated ISP interface mode.

Prototype

```
Void (*runBootloader) (void *arg)
```

Table 96. API Prototype Fields

| Field         | Offset  | Description                                                |
|---------------|---------|------------------------------------------------------------|
| TAG           | [31:24] | Fixed value: 0xEB (Enter boot mode)                        |
| Boot mode     | [23:20] | 0: Enter passive mode<br>1: Enter ISP mode                 |
| ISP interface | [19:16] | 0: Auto detection<br>1: USB HIID<br>2: UART<br>5: Reserved |
| Reserved      | [15:4]  |                                                            |
| Image index   | [03:00] | Used for Boot mode 0                                       |

#### 20.2.8.2 Flash Driver API

Flash driver API provides the flash operation supported by CM33 based on flash technology.

```

///! @brief Interface for the flash driver.
typedef struct FlashDriverInterface
{
    // Flash driver
    status_t (*flash_init)(flash_config_t *config);
    status_t (*flash_erase_sector)(flash_config_t *config, uint32_t start, uint32_t lengthInBytes, uint32_t key);
    status_t (*flash_program_phrase)(flash_config_t *config, uint32_t start, uint8_t *src, uint32_t lengthInBytes);
    status_t (*flash_program_page)(flash_config_t *config, uint32_t start, uint8_t *src, uint32_t lengthInBytes);
    status_t (*flash_verify_program)(flash_config_t *config,
                                    uint32_t start,
                                    uint32_t lengthInBytes,
                                    const uint8_t *expectedData,
                                    uint32_t *failedAddress,
                                    uint32_t *failedData);
    status_t (*flash_verify_erase_phrase)(flash_config_t *config, uint32_t start, uint32_t lengthInBytes);
    status_t (*flash_verify_erase_page)(flash_config_t *config, uint32_t start, uint32_t lengthInBytes);
    status_t (*flash_verify_erase_sector)(flash_config_t *config, uint32_t start, uint32_t lengthInBytes);
    status_t (*flash_get_property)(flash_config_t *config, flash_property_tag_t whichProperty, uint32_t *value);
    // IFR driver
    status_t (*ifr_verify_erase_phrase)(flash_config_t *config, uint32_t start, uint32_t lengthInBytes);
    status_t (*ifr_verify_erase_page)(flash_config_t *config, uint32_t start, uint32_t lengthInBytes);
    status_t (*ifr_verify_erase_sector)(flash_config_t *config, uint32_t start, uint32_t lengthInBytes);
    status_t (*flash_read)(flash_config_t *config, uint32_t start, uint8_t *dest, uint32_t lengthInBytes);
    // version
    standard_version_t version; //!< flash driver API version number.
} flash_driver_interface_t;

```

And struct of flash\_config\_t is defined as:

```

/*! @brief Flash driver state information.
*
* An instance of this structure is allocated by the user of the flash driver and
* passed into each of the driver APIs.
*/
typedef struct
{
    uint32_t PFlashBlockBase; /*!< A base address of the first PFlash block */
    uint32_t PFlashTotalSize; /*!< The size of the combined PFlash block. */
    uint32_t PFlashBlockCount; /*!< A number of PFlash blocks. */
    uint32_t PFlashPageSize; /*!< The size in bytes of a page of PFlash. */
    uint32_t PFlashSectorSize; /*!< The size in bytes of a sector of PFlash. */
    flash_ffr_config_t ffrConfig;
    // flash_mode_config_t modeConfig;
} flash_config_t;

```

Table 97. Flash driver API function details

| Function name        | Description                                                                 |
|----------------------|-----------------------------------------------------------------------------|
| Flash_init           | Initializes the global flash properties structure members                   |
| Flash_erase_sector   | Erases the flash sectors encompassed by parameters passed into function     |
| Flash_program_phrase | Programs flash phrases with data at locations passed in through parameters  |
| Flash_program_page   | Programs flash with data at locations passed in through parameters          |
| Flash_verify_program | Verifies programming of the desired flash area at a specified margin level. |

Table continues on the next page...

**Table 97. Flash driver API function details (continued)**

| Function name             | Description                                           |
|---------------------------|-------------------------------------------------------|
| Flash_verify_erase_phrase | Verify that the flash phrases are erased              |
| Flash_verify_erase_page   | Verify that the flash pages are erased                |
| Flash_verify_erase_sector | Verify that the flash sectors are erased              |
| Flash_get_property        | Returns the desired flash property                    |
| ifr_verify_erase_phrase   | Verify that the IFR0 phrases are erased               |
| ifr_verify_erase_page     | Verify that the IFR0 pages are erased                 |
| ifr_verify_erase_sector   | Verify that the IFR0 sectors are erased               |
| flash_read                | Reads flash at locations passed in through parameters |

**Table 98. Flash API return status code**

| Status                            | Code | Description                                                                                                 |
|-----------------------------------|------|-------------------------------------------------------------------------------------------------------------|
| kStatus_FLASH_Success             | 0    | The flash operation is successful                                                                           |
| kStatus_FLASH_InvalidArgument     | 4    | Invalid argument during executing API                                                                       |
| kStatus_FLASH_SizeError           | 100  | Invalid size during executing API                                                                           |
| kStatus_FLASH_AlignmentError      | 101  | Alignment error during executing API                                                                        |
| kStatus_FLASH_AddressError        | 102  | Address error during executing API                                                                          |
| kStatus_FLASH_AccessError         | 103  | Invalid instruction codes during executing API                                                              |
| kStatus_FLASH_ProtectionViolation | 104  | Protection violation flag, indicate that program/erase operation is requested to execute on protected areas |
| kStatus_FLASH_CommandFailure      | 106  | Command execution failure during executing API                                                              |
| kStatus_FLASH_UnknownProperty     | 106  | Unknown property when to call flash_get_property                                                            |
| kStatus_FLASH_EraseKeyError       | 107  | Invalid EraseKey during executing flash_erase API                                                           |

## 20.3 Life Cycle

### 20.3.1 Overview

MCXA1 supports a life cycle state model to protect code from reading from the device internal flash, which is called code read protection feature. There are different levels of protection in the system, so that access to the on-chip flash and use of ISP can be restricted. Also the life cycle state of the device determines the debug access and ISP command availability and ROP\_STATE(IFR0).

The Boot ROM checks the lifecycle state, and then determines what boot flow is to run, debug port to be enabled/locked and available debug mail access command sets. After ROM exits to extended bootloader, life cycle is checked again to determine available ISP command sets.

### 20.3.2 Life Cycle State transition



### 20.3.3 Life cycle states

MCXA1 supports below lifecycle states,

**Table 99. Life Cycle**

| Life Cycle         | Life Cycle Type | Description                                                                  |
|--------------------|-----------------|------------------------------------------------------------------------------|
| Develop            | Customer        | Initial customer development state after leaving NXP manufacturing           |
| In field ROP1/ROP2 | Customer        | In-field application state, with ROP protection                              |
| In-field ROP3      | Customer        | In-field application state, with ROP protection, prevent use of field return |
| Bricked            | End-of-life     | Bricked state to prevent device use                                          |

#### 20.3.4 Read Out Protection (ROP)

MCXA1 does not support secure boot, but it does support four levels of Read Out Protection (ROP), also referred as ROP\_STATE. This read out protection is a mechanism that allows user to enable different levels of protection in the system. It is a 32-bit field stored in IFR0. It can be programmed by customer.

- ROP\_LEVEL0, ROP\_STATE = 0xFFFF\_FFFF (erased FLASH value), no ROP. Default for blank state.
- ROP\_LEVEL1, ROP\_STATE = 0x0000\_0003

Debug is disabled and unlocked, however it can be modified by customer, only limited debug mailbox commands are available.

- ROP\_LEVEL2, ROP\_STATE = 0x0000\_0001

Debug is disabled and locked, it cannot be modified by customer, only limited debug mailbox commands are available.

- ROP\_LEVEL3, ROP\_STATE = 0x0000\_0000

Debug is disabled and locked, it cannot be modified by customer, no debug mailbox commands are available

- Anything else = ROP3-like behavior (Debug disabled/Locked, ISP disabled)
- ROP\_STATE

Value can be read out from SYSCON-> ROP\_STATE (read/write register)

ROM reads ROP\_STATE from ROP\_STATE and ROP\_STATE\_DP on IFR0, does the compare, and if it does not match, resets the device; if match, then programs it to SYSCON->ROP\_STATE.

**Table 100. ROP\_STATE IFRR0 locations**

| IFR0         | IFR0 Address |
|--------------|--------------|
| ROP_STATE    | 0x0100_0090  |
| ROP_STATE_DP | 0x0100_00A0  |

See [Debugger Mailbox Access Port and Debug session protocol](#) for details.

#### 20.4 Debugger Mailbox Access Port and Debug session protocol

The Debugger Mailbox Access Port(DM-AP) offers a register-based mailbox accessible by CPU0 (on MXCA1, there is only core CM33) and the device debug port (DP) of the MCU. Debug MailBox allows the debugger to communicate with ROM. It is protected by life cycle state. ROM controls the debug port based on LC State. This device doesn't contain security hardware, so the Debug session protocol is followed to interact with tools over SWD interface.

The protocol has following features:

- Request/response based

- Support for relatively large command and response data
- All commands and responses are 32-bit word aligned
- Support data above 32-bits by using ACK\_TOKEN that moderates the transfer in 32-bit value chunks
- Requests and responses use the same basic structure

## 20.4.1 Debug session protocol

### 20.4.1.1 Request packet layout

The first word transmitted in a request is a header word containing the command ID and number of following data words. The command packet is set to the device by writing 32-bits at a time to the REQUEST register. When sending command packets greater than 32-bits, the debugger should read an ACK\_TOKEN in the RETURN register before writing the next 32-bits.

Following the header are the number of 32-bit words specified in the header.

Table 101. Request Register Byte Description

| Word | Byte 0         | Byte 1          | Byte 2             | Byte 3              |
|------|----------------|-----------------|--------------------|---------------------|
| 0    | commandID[7:0] | commandID[15:8] | dataWordCount[7:0] | dataWordCount[15:8] |
| 1    | data...        |                 |                    |                     |

The C structure definition for a request is as follows:

```
struct dm_request {
    uint16_t commandID;
    uint16_t dataWordCount;
    uint32_t data[];
};
```

### 20.4.1.2 Response packet layout

Response register byte description structure is the same as Request register byte description.

Table 102. Response Packet Byte Description

| Word | Byte 0             | Byte 1              | Byte 2             | Byte 3                                  |
|------|--------------------|---------------------|--------------------|-----------------------------------------|
| 0    | commandStatus[7:0] | commandStatus[15:8] | dataWordCount[7:0] | dataWordCount[14:8]<br>new_protocol[15] |
| 1    | data...            |                     |                    |                                         |

The C structure definition for a response is as follows:

```
struct dm_response {
    uint16_t commandID;
    uint16_t dataWordCount;
    uint32_t data[];
};
```

### 20.4.1.3 ACK\_TOKEN

- When command has parameters the debugger should wait for ACK\_TOKEN (sent through DBG\_MB\_RETURN register) before sending next 32-bit value.
- Similarly when response packet has data to send back to debugger, ROM will wait for debugger to send ACK\_TOKEN (sent through DBG\_MB\_REQUEST register) before sending next 32-bit value.
- Upper 16-bits are set by receiving end with number of remaining words expected.
- Lower 16-bits are always set to 0xA5A5.

Table 103. ACK\_TOKEN Register Byte Description

| Word | Byte 0 | Byte 1 | Byte 2           | Byte 3            |
|------|--------|--------|------------------|-------------------|
| 0    | 0xA5   | 0xA5   | remainCount[7:0] | remainCount[15:8] |

The C structure definition for a ACK\_TOKEN is as follows:

```
struct dm_ack_token {
    uint16_t token; /* always set to 0xA5A5
    uint16_t remainCount; /* count of remaining word
};
```

### 20.4.1.4 Error handling

When an overrun occurs from either side of the communication, the appropriate error flag is set in the CSW register. The state machine hardware prevents further communication in either direction. The debugger must start with a new resynchronization request to clear the error flag.

## 20.4.2 DM-AP command

### 20.4.2.1 All DM-AP command

This table lists all DM-AP commands supported by this device.

Table 104. DM-AP commands

| Command                         | ID   | Parameter/Response                                  | Description                                                                                             |
|---------------------------------|------|-----------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| Start DM-AP<br>(Legacy command) | 0x01 | Parameters: None<br><i>Response</i> : 32-bit status | Cause the device to enter DM-AP command mode.<br><br>This must be done prior to sending other commands. |
| Get ROP Level                   | 0x02 | Parameters: None<br><i>Response</i> : 32-bit status | Return the ROP level value                                                                              |
| Bulk Erase<br>(Legacy command)  | 0x03 | Parameters: None<br><i>Response</i> : 32-bit status | Erase the entire on-chip flash memory (IFR0, sector 0).                                                 |
| Exit DM-AP<br>(Legacy command)  | 0x04 | Parameters: None<br><i>Response</i> : 32-bit status | Cause the device to exit DM-AP command mode. The                                                        |

*Table continues on the next page...*

Table 104. DM-AP commands (continued)

| Command                                       | ID   | Parameter/Response                                                                                                       | Description                                                                                                                      |
|-----------------------------------------------|------|--------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
|                                               |      |                                                                                                                          |                                                                                                                                  |
| Enter ISP Mode<br>((For Extended bootloader)) | 0x05 | Parameters:<br>dataWordCount: 0x1<br>data[0]: ISP mode enum. Same as IAP API.<br><i>Response:</i> 32-bit status          | Device returns to normal mode.<br>Enter specified ISP mode.                                                                      |
| Set FA Mode                                   | 0x06 | Parameters:<br>dataWordCount: 0xFE<br>data[]: FA Request<br><i>Response:</i> 32-bit status                               | Set the part permanently in "Fault Analysis" mode to return to NXP factory.                                                      |
| Start Debug Session                           | 0x07 | Parameters: None<br><i>Response:</i> 32-bit status                                                                       | This command is used to indicate ROM the intention of connecting debugger.<br>ROM enables debug access and enters while(1) loop. |
| Write words to flash<br>(New)                 | 0x09 | Parameters:<br>dataWordCount: 0x5<br>data[0]: FlashAddress data[4]: data to be written<br><i>Response:</i> 32-bit status | Write four words (128 bits) to flash<br>Flash address must be 16-bit aligned                                                     |
| Read words from flash<br>(New)                | 0x0A | Parameters:<br>dataWordCount: 0x5<br>data[0]: FlashAddress<br><i>Response:</i> 32-bit status<br>data[4]: Data out        | Read four words from flash<br>Flash address must be 16-bit aligned                                                               |
| Erase one Sector (New)                        | 0x0B | Parameters:<br>dataWordCount: 0x1<br>data[0]: flash page index<br><i>Response:</i> 32-bit status                         | Erase one flash sector                                                                                                           |

#### 20.4.2.2 Available debug mailbox commands per life cycle

Available debug mailbox command sets depend on life cycle state and read out protection level. If the part is in Bricked state, or OEM Closed No return state, then ROM will lock the part, and no debug mail commands are available.

The table below summarizes available debug mail box commands corresponding to read out protection level and life cycle state.

Table 105. Debug Mailbox Command Sets Per Life Cycle State

| LC management | Available commands                                                                                                                                                                                             |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Develop       | Start DM-AP<br>Get_ROP_Level,<br>Bulk_Erase, (user flash and IFR0 sector 0)<br>Exit DM-AP<br>Enter_ISP_Mode,<br>Set_FA_Mode<br>Start Debug Session,<br>Write_Flash_Word<br>Read_Flash_Word<br>Erase_One_Sector |
| In-field ROP1 | Start DM-AP<br>Get_ROP_Level<br>Bulk_Erase (user flash and IFR0 sector 0)<br>Enter_ISP_Mode,<br>Set_FA_Mode<br>Exit DM-AP                                                                                      |
| In-field ROP2 | Start DM-AP<br>Get_ROP_Level<br>Bulk_Erase (user flash and IFR0 sector 0)<br>Set_FA_Mode,<br>Exit DM-AP                                                                                                        |
| In-field ROP3 | Debug mail box is not available                                                                                                                                                                                |
| Bricked       | Debug mail box is not available                                                                                                                                                                                |

## 20.5 Extended Bootloader and In-System programming (ISP)

### 20.5.1 Overview

After a POR or WARM reset sequence, CPU always starts the ROM code execution in Boot ROM memory. After the operations in Boot ROM, the control of CPU is transferred to the extended bootloader in flash IFR0 memory. This extended bootloader only supports load non-secure image (image format specified in Boot ROM section) to on-chip memory, including RAM and flash. Also bootloader will integrity check if CRC check is present in the image header before jumping to the user image.

Note the booting available peripherals as given below.

Bootloader features:

- Extended bootloader size can be up to 24 KB (IFR0, sector 1 ~ 3)
- Booting on USB FS HID interface and LPUART interface with auto-baud detection

- Supports ISP calls path
- Low power wakeup path
- Phantom part configuration
- Image update and swap
- No need to implement Debug Mailbox commands since it is done by ROM
- Does not support dual image boot and image version

## 20.5.2 Boot peripherals and default pins

Table 106. Bootloader Peripheral Pinmux

| Peripheral | Instance | Alt Mode | Port        | GPIO    |
|------------|----------|----------|-------------|---------|
| LPUART     | 0        | 2        | LPUART0_RXD | P0_2    |
|            |          |          | LPUART0_TXD | P0_3    |
| USB        | 0        |          | USB0_DM     | USB0_DM |
|            |          |          | USB0_DP     | USB0_DP |

## 20.5.3 Functional description

### 20.5.3.1 Jump to user application path

With successfully integrity CRC check on user application, before jumping to user application, the extended bootloader needs to:

- Shutdown all the boot peripherals
- Restore the registers to default values. These registers are used by all modules used by ROM or extended bootloader, except MBC and GLIKEY settings.
- Set GLIKEY and MBC settings based on life cycle.

### 20.5.3.2 Lower power wakeup Path

On Deep-Sleep wake-up or Sleep wake-up, the core would continue executing application without any ROM- or HW-enforced checks. It would be up to the application to implement its own checks if a customer deems necessary.

The difference between ROM and extended bootloader on lower power wakeup path is that extended bootloader run CRC check on user image if image indicates valid image type at offset 0x24 (reserved word of vector table)

When the integrity CRC check is successfully passed, it jumps to wakeup entry specified in IFR0; otherwise enters into ISP path in extended bootloader.



Figure 32. Extended bootloader DPD wake-up flow

#### 20.5.3.3 Supported ISP calls path

Due to limited IFR0 memory space, extended bootloader support the following commands.

- ReadMemory
- FlashEraseAll (user flash and IFR0 Sector 0)
- FlashEraseRegion
- Reset
- WriteMemory
- GetProperty
- Execute

Reduced ISP command set:

- FlashEraseAll (user flash and IFR0 Sector 0)
- Reset
- GetProperty

However available commands set highly depend on the device life cycle. Life cycle management is the same as in ROM section.

**Table 107. Available ISP commands set per Life Cycle State**

| LC State      | Available commands set                                                                                                                 |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Develop       | Full ISP command set                                                                                                                   |
| In-field ROP1 | Reduced command set if entry through:<br>ISP_PIN, INVALID_IMAGE, DEBUG_MAILBOX<br>Full command set if entry through:<br>bootloader_API |
| In-field ROP2 | Reduced command set if entry through:<br>INVALID_IMAGE, bootloader_API                                                                 |
| In-field ROP3 | No ISP commands are available                                                                                                          |
| Bricked       | No ISP commands are available                                                                                                          |

#### 20.5.4 Flash Swap path

Extended bootloader supports flash swap, which is the function of FMC. On MCXA1, there is only one bank of flash, which is divided into four regions: two swappable regions, and two static regions.

- Lower swappable region (swappable region 0): flash physical start address ~ limit
- Lower static region (static region 0): limit + 1 ~ half size of flash – 1
- Upper swappable region (swappable region 1): half size of flash ~ half size of flash + limit
- Upper static region (static region 1): half size of flash + limit + 1 ~ size of flash – 1

To able to run flash swap, the basic requirements are:

1. Size of swappable region 0 equals to size of swappable region 1
2. Size of swappable region 0 plus size of static region 0 equals to half size of flash



#### 20.5.4.1 Flash swap flow chart



#### 20.5.5 In-System Programming (ISP) Protocol

This section explains the general protocol for the packet transfers between the host and the bootloader. The description includes the transfer of packets for different transactions, such as commands with no data phase and commands with incoming or outgoing data phase. The next section describes various packet types used in a transaction.

Each command sent from the host is replied to with a response command.

Commands may include an optional data phase.

- If the data phase is incoming (from the host to the bootloader), it is part of the original command.
- If the data phase is outgoing (from the bootloader to host), it is part of the response command.

### 20.5.5.1 Command with no data phase

The protocol for a command with no data phase contains:

- Command packet (from the host)
- Generic response command packet (to host)



Figure 33. Command with No Data Phase

#### NOTE

In these diagrams, the ACK sent in response to a command or a data packet can arrive at any time before, during, or after the command or data packet has processed.

### 20.5.5.2 Command with the incoming data phase

The protocol for a command with incoming data phase contains:

- Command packet (from host) (kCommandFlag\_HasDataPhase set).
- Generic response command packet (to host).
- Incoming data packets (from the host).
- Generic response command packet.
- The host may not send any further packets while it is waiting for the response to a command.
- The data phase is aborted if the Generic Response packet prior to the start of the Data phase does not have a status of kStatus\_Success.
- Data phases may be aborted by the receiving side by sending the final GenericResponse early with a status of kStatus\_AbortDataPhase. The host may abort the data phase early by sending a zero-length data packet.
- The final Generic Response packet sent after the data phase includes the status of the entire operation.



Figure 34. Command with incoming data phase

#### 20.5.5.3 Command with the outgoing data phase

The protocol for a command with an outgoing data phase contains:

- Command packet (from the host).
- ReadMemory Response command packet (to host) (kCommandFlag\_HasDataPhase set).
- Outgoing data packets (to host).
- Generic response command packet (to host).



Figure 35. Command with Outgoing Data Phase

## 20.5.6 Bootloader packet types

### 20.5.6.1 Introduction

The bootloader device works in slave mode. All data communications are initiated by a host, which is either a PC or an embedded host. The bootloader device is the target, which receives a command or data packet. All data communications between host and target are packetized.

There are six types of packets used:

- Ping packet.
- Ping Response packet.
- Framing packet.

- Command packet.
- Data packet.
- Response packet.

All fields in the packets are in little-endian byte order.

### 20.5.7 Ping packet

The Ping packet is the first packet sent from a host to the target to establish a connection on the selected peripheral in order to run autobaud detection. The Ping packet can be sent from host to target at any time that the target is expecting a command packet. If the selected peripheral is UART, a Ping packet must be sent before any other communications. For other serial peripherals, it is optional.

In response to a Ping packet, the target sends a Ping response packet, discussed in the later sections.

**Table 108. Ping Packet Format**

| Byte # | Value | Name       |
|--------|-------|------------|
| 0      | 0x5A  | Start byte |
| 1      | 0xA6  | Ping       |



**Figure 36. Ping Packet Protocol Sequence**

#### 20.5.7.1 Ping response packet

The target sends a Ping response packet back to the host after receiving a Ping packet. If communication is over a UART peripheral, the target uses the incoming Ping packet to determine the baud rate before replying with the Ping response packet. Once the Ping response packet is received by the host, the connection is established, and the host starts sending commands to the target.

**Table 109. Ping Response Packet Format**

| Byte | Value | Parameter  |
|------|-------|------------|
| 0    | 0x5A  | Start byte |

*Table continues on the next page...*

Table 109. Ping Response Packet Format (continued)

| Byte | Value | Parameter                  |
|------|-------|----------------------------|
| 1    | 0xA7  | Ping response code         |
| 2    | 0x00  | Protocol bugfix            |
| 3    | 0x03  | Protocol minor             |
| 4    | 0x01  | Protocol major             |
| 5    | 0x50  | Protocol name = 'P' (0x50) |
| 6    | 0x00  | Options low                |
| 7    | 0x00  | Options high               |
| 8    | 0xfb  | CRC16 low                  |
| 9    | 0x40  | CRC16 high                 |

For the UART peripheral, it must be sent by the host when a connection is first established, in order to run outbound. For other serial peripherals, it is optional but recommended to determine the serial protocol version. The version number is in the same format as the bootloader version number returned by the GetProperty command.

### 20.5.7.2 Framing packet

The framing packet is used for flow control and error detection for the communications links that do not have such features built in. The framing packet structure sits between the link layer and the command layer. It wraps command and data packets as well.

Every framing packet containing data sent in one direction results in a synchronizing response framing packet in the opposite direction.

The framing packet described in this section is used for serial peripherals including the UART. The USB HID peripheral does not use framing packets. Instead, the packetization inherent in the USB protocol itself is used.

Table 110. Framing Packet Format

| Byte   | Value | Parameter                      | Description                                                                                                                                                     |
|--------|-------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | 0x5A  | Start byte                     |                                                                                                                                                                 |
| 1      |       | PacketType                     |                                                                                                                                                                 |
| 2      |       | Length_low                     | Length is a 16-bit field that specifies the entire command or data packet size in bytes.                                                                        |
| 3      |       | Length_high                    |                                                                                                                                                                 |
| 4      |       | Crc16_low                      | This is a 16-bit field. The CRC16 value covers entire framing packet, including the start byte and command or data packets, but does not include the CRC bytes. |
| 5      |       | Crc16_high                     | See <a href="#">CRC16 algorithm</a> .                                                                                                                           |
| 6....n |       | Command or Data packet payload |                                                                                                                                                                 |

A special framing packet that contains only a start byte and a packet type is used for synchronization between the host and target.

**Table 111. Special Framing Packet Format**

| Byte | Value   | Parameter  |
|------|---------|------------|
| 0    | 0x5A    | Start byte |
| 1    | 0xA $n$ | packetType |

The Packet Type field specifies the type of the packet from one of the defined types (below):

**Table 112. Packet Type Field**

| Packet type | Name                            | Description                                                                            |
|-------------|---------------------------------|----------------------------------------------------------------------------------------|
| 0xA1        | kFramingPacketType_Ack          | The previous packet was received successfully; the sending of more packets is allowed. |
| 0xA2        | kFramingPacketType_Nak          | The previous packet was corrupted and must be re-sent.                                 |
| 0xA3        | kFramingPacketType_AckAbort     | Data phase is being aborted.                                                           |
| 0xA4        | kFramingPacketType_Command      | The framing packet contains a command packet payload.                                  |
| 0xA5        | kFramingPacketType_Data         | The framing packet contains a data packet payload.                                     |
| 0xA6        | kFramingPacketType_Ping         | Sent to verify the other side is alive. Also used for UART autobaud.                   |
| 0xA7        | kFramingPacketType_PingResponse | A response to Ping. It contains the framing protocol version number and options.       |

### 20.5.7.3 CRC16 algorithm

The CRC is computed over each byte in the framing packet header, excluding the CRC16 field itself, and all of the payload bytes. The CRC algorithm is the XMODEM variant of

CRC16.

The characteristics of the XMODEM variants are:

**Table 113. CRC16 Algorithm**

|              |        |
|--------------|--------|
| Width        | 16     |
| Polynomial   | 0x1021 |
| Init value   | 0x0000 |
| Reflect in   | False  |
| Reflect out  | False  |
| Xor out      | 0x0000 |
| Check result | 0x31C3 |

The check result is computed by running the ASCII character sequence "123456789" through the algorithm.

```

uint16_t crc16_update(const uint8_t * src, uint32_t lengthInBytes) uint32_t crc = 0;
{
    uint32_t j;
    for (j=0; j < lengthInBytes; ++j)
    {
        uint32_t i;
        uint32_t byte = src[j];
        crc ^= byte << 8;
        for (i = 0; i < 8; ++i)
        {
            uint32_t temp = crc << 1;
            if (crc & 0x8000)
            {
                temp ^= 0x1021;
            }
            crc = temp;
        }
    }
    return crc;
}

```

#### 20.5.7.4 Command packet

The command packet carries a 32-bit command header and a list of 32-bit parameters.

Table 114. Command Packet Format

|                                     |       |      |             |                                            |                     |                     |                     |                     |                     |                     |  |  |
|-------------------------------------|-------|------|-------------|--------------------------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|--|--|
| Command Packet Format<br>(32 bytes) |       |      |             |                                            |                     |                     |                     |                     |                     |                     |  |  |
| Command Header (4 bytes)            |       |      |             | 28 bytes for Parameters (Max 7 parameters) |                     |                     |                     |                     |                     |                     |  |  |
| Tag                                 | Flags | Rsvd | Param Count | Param 1<br>(32-bit)                        | Param 2<br>(32-bit) | Param 3<br>(32-bit) | Param 4<br>(32-bit) | Param 5<br>(32-bit) | Param 6<br>(32-bit) | Param 7<br>(32-bit) |  |  |

Table 115. Command Header Format

| Byte # | Command header field      | Reset value                                           |
|--------|---------------------------|-------------------------------------------------------|
| 0      | Command or Response tag   | The command header is 4 bytes long with these fields. |
| 1      | Flags                     |                                                       |
| 2      | Reserved. Should be 0x00. |                                                       |
| 3      | ParameterCount            |                                                       |

The header is followed by 32-bit parameters up to the value of the ParameterCount field specified in the header. Because a command packet is 32 bytes long, only seven parameters can fit into the command packet.

Command packets are also used by the target to send responses back to the host. As mentioned earlier, command packets and data packets are embedded into framing packets for all of the transfers.

**Table 116. Command Tags**

| Command tag | Name             | Description                                                                                                                           |
|-------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| 0x01        | FlashEraseAll    | The command tag specifies one of the commands supported by the bootloader. The valid command tags for the bootloader are listed here. |
| 0x02        | FlashEraseRegion |                                                                                                                                       |
| 0x03        | ReadMemory       |                                                                                                                                       |
| 0x04        | WriteMemory      |                                                                                                                                       |
| 0x07        | GetProperty      |                                                                                                                                       |
| 0x09        | Execute          |                                                                                                                                       |
| 0x0B        | Reset            |                                                                                                                                       |

**Table 117. Response Tags**

| Response tag | Name                                                                         | Description                                                                                                                              |
|--------------|------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 0xA0         | GenericResponse                                                              | The response tag specifies one of the responses the bootloader (target) returns to the host.<br>The valid response tags are listed here. |
| 0xA7         | GetPropertyResponse (used for sending responses to GetProperty command only) |                                                                                                                                          |
| 0xA3         | ReadMemoryResponse (used for sending responses to ReadMemory command only)   |                                                                                                                                          |

**Flags:** Each command packet contains a flag byte. Only bit 0 of the flag byte is used. If bit 0 of the flag byte is set to 1, then data packets follow the command sequence. The number of bytes that are transferred in the data phase is determined by a command specific parameter in the parameters array.

**ParameterCount:** The number of parameters included in the command packet.

**Parameters:** The parameters are word-length (32 bits). With the default maximum packet size of 32 bytes, a command packet can contain up to seven parameters.

### 20.5.7.5 Response packet

The responses are carried using the same command packet format wrapped with framing packet data. Types of responses include:

- GenericResponse
- GetPropertyResponse
- ReadMemoryResponse

**GenericResponse:** After the bootloader has processed a command, the bootloader sends a generic response with status and command tag information to the host. The generic response is the last packet in the command protocol sequence. The generic response packet contains the framing packet data and the command packet data (with generic response tag = 0xA0) and a list of parameters (defined in the next section). The parameter count field in the header is always set to 2, for status code and command tag parameters.

**Table 118. Generic Response Parameters**

| Byte # | Parameter   | Description                                                                                                                                              |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 - 3  | Status code | The Status codes are errors encountered during the execution of a command by the target. If a command succeeds, then a kStatus_Success code is returned. |
| 4 - 7  | Command tag | The Command tag parameter identifies the response to the command sent by the host.                                                                       |

**GetPropertyResponse:** The GetPropertyResponse packet is sent by the target in response to the host query that uses the GetProperty command. The GetPropertyResponse packet contains the framing packet data and the command packet data, with the command/response tag set to a GetPropertyResponse tag value (0xA7).

The parameter count field in the header is set to greater than 1, to always include the status code and one or many property values.

**Table 119. GetPropertyResponse Parameters**

| Byte # | Value | Parameter                                                                                                   |
|--------|-------|-------------------------------------------------------------------------------------------------------------|
| 0 - 3  |       | Status code                                                                                                 |
| 4 - 7  |       | Property value                                                                                              |
| ...    |       | ...                                                                                                         |
|        |       | Can be up to maximum 6 property values, limited to the size of the 32-bit command packet and property type. |

**ReadMemoryResponse:** The ReadMemoryResponse packet is sent by the target in response to the host sending a ReadMemory command. The ReadMemoryResponse packet contains the framing packet data and the command packet data, with the command/response tag set to a ReadMemoryResponse tag value (0xA3), the flags field set to kCommandFlag\_HasDataPhase (1).

The parameter count set to two for the status code and the data byte count parameters shown below.

**Table 120. ReadMemoryResponse Parameters**

| Byte # | Parameter       | Description                                       |
|--------|-----------------|---------------------------------------------------|
| 0 - 3  | Status code     | The status of the associated Read Memory command. |
| 4 - 7  | Data byte count | The number of bytes sent in the data phase.       |

**FlashReadOnceResponse:** The FlashReadOnceResponse packet is sent by the target in response to the host sending a FlashReadOnce command. The FlashReadOnceResponse packet contains the framing packet data and the command packet data, with the command/response tag set to a FlashReadOnceResponse tag value (0xAF), and the flags field set to 0. The parameter count is set to 2 plus *the number of words* requested to be read in the FlashReadOnceCommand.

## 20.5.8 ISP commands set

Available ISP commands set is limited per life cycle state.

**Table 121.** ISP Commands Set

| Life Cycle                     | Command sets                                                                                                                   |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| NXP Provisioned                | Full commands set:                                                                                                             |
| OEM Open                       | <ul style="list-style-type: none"> <li>• ReadMemory</li> </ul>                                                                 |
| OEM Field Return               | <ul style="list-style-type: none"> <li>• FlashEraseAll</li> </ul>                                                              |
| NXP Field Return               | <ul style="list-style-type: none"> <li>• FlashEraseRegion</li> </ul>                                                           |
| NXP Closed with Bootloader_API | <ul style="list-style-type: none"> <li>• Reset</li> <li>• WriteMemory</li> <li>• GetProperty</li> <li>• Execute</li> </ul>     |
| OEM Closed<br>(ROp1 or ROP2)   | Partial commands set <ul style="list-style-type: none"> <li>• FlashEraseAll</li> <li>• Reset</li> <li>• GetProperty</li> </ul> |
| OEM Closed No Return           | NA                                                                                                                             |
| Bricked                        |                                                                                                                                |

#### 20.5.8.1 GetProperty command

The GetProperty command is used to query the bootloader about various properties and settings. Each supported property has a unique 32-bit tag associated with it. The tag occupies the first parameter of the command packet. The target returns a GetPropertyResponse packet with the property values for the property identified with the tag in the GetProperty command.

Properties are the defined units of data that can be accessed with the GetProperty or SetProperty commands. Properties may be read-only or read-write. All read-write properties are 32-bit integers, so they can easily be carried in a command parameter.

The 32-bit property tag is the only parameter required for GetProperty command.

**Table 122.** Parameters for GetProperty Command

| Byte # | Parameter                                                                                                                              |
|--------|----------------------------------------------------------------------------------------------------------------------------------------|
| 0 - 3  | Property tag                                                                                                                           |
| 4 - 7  | External Memory Identifier (only applies to get property for external memory, or status identifier if the property tag is equal to 8). |



Table 123. GetProperty Command Packet Format (Framing example)

| GetProperty    | Parameter  | Value                            |
|----------------|------------|----------------------------------|
| Framing packet | Start byte | 0x5A                             |
|                | PacketType | 0xA4, kFramingPacketType_Command |
|                | Length     | 0x0C 0x00                        |
|                | Crc16      | 0x4B 0x33                        |

**Table 124. GetProperty Command Packet Format (example)**

| GetProperty    | Parameter      | Value                       |
|----------------|----------------|-----------------------------|
| Command packet | CommandTag     | 0x07 – GetProperty          |
|                | Flags          | 0x00                        |
|                | Reserved       | 0x00                        |
|                | ParameterCount | 0x02                        |
|                | PropertyTag    | 0x00000001 - CurrentVersion |
|                | Memory ID      | 0x00000000 - Internal Flash |

The GetProperty command has no data phase.

**Response:** In response to a GetProperty command, the target sends a GetPropertyResponse packet with the response tag set to 0xA7. The parameter count indicates the number of parameters sent for the property values, with the first parameter showing status code 0, followed by the property value(s). [Table 4-20](#) shows an example of a GetPropertyResponse packet.

Table 125. GetProperty Response Packet Format (example)

| GetPropertyResponse | Parameter      | Value                            |
|---------------------|----------------|----------------------------------|
| Framing packet      | Start byte     | 0x5A                             |
|                     | PacketType     | 0xA4, kFramingPacketType_Command |
|                     | Length         | 0x0c 0x00 (12 bytes)             |
|                     | Crc16          | 0x07 0x7a                        |
| Command packet      | ResponseTag    | 0xA7                             |
|                     | Flags          | 0x00                             |
|                     | Reserved       | 0x00                             |
|                     | ParameterCount | 0x02                             |
|                     | Status         | 0x00000000                       |
|                     | PropertyValue  | 0x0000014b - CurrentVersion      |

#### 20.5.8.2 FlashEraseAll command

The FlashEraseAll command performs an erase of the entire flash memory. If any flash regions are protected, then the FlashEraseAll command fails and returns an error status code. The Command tag for FlashEraseAll command is 0x01 set in the commandTag field of the command packet.

The FlashEraseAll command requires memory ID. If memory ID is not specified, the internal flash (memory ID =0) will be selected as default.

Table 126. Parameter for FlashEraseAll Command

| Byte # | Parameter |                |
|--------|-----------|----------------|
| 0-3    | Memory ID |                |
|        | 0x000     | Internal Flash |



Figure 38. Protocol sequence for FlashEraseAll command

Table 127. FlashEraseAll command packet format (example)

| FlashEraseAll  | Parameter      | Value                            |
|----------------|----------------|----------------------------------|
| Framing packet | Start byte     | 0x5A                             |
|                | PacketType     | 0xA4, kFramingPacketType_Command |
|                | Length         | 0x08 0x00                        |
|                | Crc16          | 0x0C 0x22                        |
| Command packet | CommandTag     | 0x01 - FlashEraseAll             |
|                | Flags          | 0x00                             |
|                | Reserved       | 0x00                             |
|                | ParameterCount | 0x01                             |
|                | Memory ID      | See Table 126                    |

The FlashEraseAll command has no data phase.

**Response:** The target returns a GenericResponse packet with status code either set to kStatus\_Success for successful execution of the command or set to an appropriate error status code.

#### 20.5.8.3 FlashEraseRegion command

The FlashEraseRegion command performs an erase of one or more sectors of the flash memory.

The start address, and number of bytes are the two parameters required for the FlashEraseRegion command. The start and byte count parameters must be 4-byte aligned ([1:0] = 00), or the FlashEraseRegion command fails and returns kStatus\_FlashAlignmentError (101). If the region specified does not fit in the flash memory space, the FlashEraseRegion command fails and returns kStatus\_FlashAddressError (102). If any part of the region specified is protected, the FlashEraseRegion command fails and returns kStatus\_MemoryRangeInvalid (10200).

**Table 128. Parameters for FlashEraseRegion Command**

| Byte # | Parameter     |
|--------|---------------|
| 0-3    | Start address |
| 4 - 7  | Byte count    |
| 8 - 11 | Memory ID     |

The FlashEraseRegion command has no data phase.



**Response:** The target returns a GenericResponse packet with one of the following error status codes.

**Table 129. FlashEraseRegion Response Status Codes**

| Status code                             |
|-----------------------------------------|
| kStatus_Success (0).                    |
| kStatus_MemoryRangeInvalid (10200).     |
| kStatus_FlashAlignmentError (101).      |
| kStatus_IFlashAddressError (102).       |
| kStatus_FlashAccessError (103).         |
| kStatus_FlashProtectionViolation (104). |
| kStatus_FlashCommandFailure (105).      |

#### 20.5.8.4 ReadMemory command

The ReadMemory command returns the contents of memory at the given address, for a specified number of bytes. This command can read any region of memory accessible by the CPU and not protected by security.

The start address, and number of bytes are the two parameters required for ReadMemory command. The memory ID is optional. Internal memory will be selected as default if memory ID is not specified.

Table 130. Parameter for Read Memory Command

| Byte # | Parameter     | Description                                   |
|--------|---------------|-----------------------------------------------|
| 0-3    | Start address | Start address of memory to read from.         |
| 4-7    | Byte count    | Number of bytes to read and return to caller. |
| 8-11   | Memory ID     | Internal or external memory Identifier.       |



Figure 40. Command sequence for ReadMemory command

Table 131. Parameter for read memory command

| ReadMemory     | Parameter   | Value                            |
|----------------|-------------|----------------------------------|
| Framing packet | Start byte  | 0x5A                             |
|                | PpacketType | 0xA4, kFramingPacketType_Command |
|                | Length      | 0x10 0x00                        |
|                | Crc16       | 0xF4 0x1B                        |
| Command packet | CommandTag  | 0x03 - ReadMemory                |
|                | Flags       | 0x00                             |

Table continues on the next page...

Table 131. Parameter for read memory command (continued)

| ReadMemory | Parameter      | Value      |
|------------|----------------|------------|
|            | Reserved       | 0x00       |
|            | ParameterCount | 0x03       |
|            | StartAddress   | 0x20000400 |
|            | ByteCount      | 0x00000064 |
|            | Memory ID      | 0x0        |

**Data Phase:** The ReadMemory command has a data phase. Because the target works in slave mode, the host needs to pull data packets until the number of bytes of data specified in the byteCount parameter of ReadMemory command are received by host.

**Response:** The target returns a GenericResponse packet with a status code either set to kStatus\_Success upon successful execution of the command or set to an appropriate error status code

#### 20.5.8.5 WriteMemory command

The WriteMemory command writes data provided in the data phase to a specified range of bytes in memory (flash or RAM). However, if flash protection is enabled, then writes to protected sectors fail.

Special care must be taken when writing to flash.

- First, any flash sector written to must have been previously erased with a FlashEraseAll or FlashEraseRegion command.
- Writing to flash requires the start address to be page aligned.
- The byte count is rounded up to a page size, and trailing bytes are filled with the flash erase pattern (0xff).
- If the VerifyWrites property is set to true, then writes to flash also performs a flash verify program operation.

When writing to RAM, the start address does not need to be aligned, and the data is not padded.

The start address and number of bytes are the two parameters required for WriteMemory command. The memory ID is optional. Internal memory will be selected as default if memory ID is not specified.

Table 132. Parameters for WriteMemory Command

| Byte # | Command       |
|--------|---------------|
| 0-3    | Start address |
| 4-7    | Byte count    |
| 8-11   | Memory ID     |



Figure 41. Command sequence for WriteMemory command

Table 133.

| WriteMemory    | Parameter      | Value                            |
|----------------|----------------|----------------------------------|
| Framing packet | Start byte     | 0x5A                             |
|                | PacketType     | 0xA4, kFramingPacketType_Command |
|                | Length         | 0x10 0x00                        |
|                | Crc16          | 0x97 0xDD                        |
| Command packet | CommandTag     | 0x04 - WriteMemory               |
|                | Flags          | 0x01                             |
|                | Reserved       | 0x00                             |
|                | ParameterCount | 0x03                             |
|                | StartAddress   | 0x20000400                       |
|                | ByteCount      | 0x00000064                       |
|                | Memory ID      | 0x0                              |

**Data Phase:** The WriteMemory command has a data phase; the host sends data packets until the number of bytes of data specified in the byteCount parameter of the WriteMemory command are received by the target.

**Response:** The target returns a GenericResponse packet with a status code set to kStatus\_Success upon successful execution of the command, or to an appropriate error status code.

### 20.5.8.6 Execute command

The Execute command results in the bootloader setting the program counter to the code at the provided jump address, R0 to the provided argument, and a Stack pointer to the provided stack pointer address. Prior to the jump, the system is returned to the reset state.

The Jump address, function argument pointer, and stack pointer are the parameters required for the Execute command. If the stack pointer is set to zero, the called code is responsible for setting the processor stack pointer before using the stack.

Table 134. Parameters for Execute Command

| Byte # | Command                |
|--------|------------------------|
| 0-3    | Jump address.          |
| 4-7    | Argument word.         |
| 8-11   | Stack pointer address. |

The Execute command has no data phase.

**Response:** Before executing the Execute command, the target validates the parameters and return a GenericResponse packet with a status code either set to kStatus\_Success or an appropriate error status code.

### 20.5.8.7 Reset command

The Reset command results in the bootloader resetting the chip.

The Reset command requires no parameters.



Figure 42. Protocol sequence for reset command

Table 135. Reset command parameter values

| Reset          | Parameter  | Value                            |
|----------------|------------|----------------------------------|
| Framing packet | Start byte | 0x5A                             |
|                | PacketType | 0xA4, kFramingPacketType_Command |
|                | Length     | 0x04 0x00                        |

*Table continues on the next page...*

Table 135. Reset command parameter values (continued)

| Reset          | Parameter      | Value        |
|----------------|----------------|--------------|
|                | Crc16          | 0x6F 0x46    |
| Command packet | CommandTag     | 0x0B - reset |
|                | Flags          | 0x00         |
|                | Reserved       | 0x00         |
|                | ParameterCount | 0x03         |

The Reset command has no data phase.

**Response:** The target returns a GenericResponse packet with status code set to kStatus\_Success, before resetting the chip.

The reset command can also be used to switch boot from flash after successful flash image provisioning via ROM bootloader. After issuing the reset command, allow five seconds for the user application to start running from Flash.

### 20.5.9 Get Properties Command properties

This section lists the properties of the GetProperty and SetProperty commands.

Get/Set property definitions are provided in this section.

Table 136. Properties Used by Get/GetProperty Commands, Sorted by Values

| Property             | Writable | Tag Value | Size | Description                                                                                                                                                                                                                                      |
|----------------------|----------|-----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CurrentVersion       | No       | 01h       | 4    | Current bootloader version.                                                                                                                                                                                                                      |
| AvailablePeripherals | No       | 02h       | 4    | The set of peripherals supported on this chip.                                                                                                                                                                                                   |
| AvailableCommands    | No       | 07h       | 4    | The set of commands supported by the bootloader                                                                                                                                                                                                  |
| Check Status         | No       | 08h       | 4    | Return the status based on specified status identifier<br>0 – CRC status<br>32-bit return value for CRC Check<br>1. Application CRC check failed<br>2. Application CRC check is inactive<br>3. Application CRC check is invalid<br>a. Last Error |
| MaxPacketSize        | No       | 0Bh       | 4    | Maximum supported packet size for the currently active peripheral interface.                                                                                                                                                                     |
| LifeCycleState       | No       | 11h       | 4    | The life cycle of the device.<br>0x5aa55aa5 – Device is in development life cycle.<br>0xc33cc33c – Device is in deployment life cycle.                                                                                                           |

*Table continues on the next page...*

**Table 136. Properties Used by Get/SetProperty Commands, Sorted by Values (continued)**

| Property           | Writable | Tag Value | Size | Description                      |
|--------------------|----------|-----------|------|----------------------------------|
| UniqueDevice/UUID  | No       | 12h       | 16   | Unique device identification     |
| Target ROM Version | No       | 18h       | 4    | The target device identification |

### 20.5.9.1 CurrentVersion property

The value of this property is a 4-byte structure containing the current version of the bootloader.

**Table 137. CurrentVersion Property fields**

| Bit   | [31:24]           | [23:16]       | [15:8]        | [7:0]          |
|-------|-------------------|---------------|---------------|----------------|
| Field | Name = 'K' (0x4B) | Major version | Major version | Bugfix version |

Get/Set property definitions are provided in this section.

### 20.5.9.2 AvailablePeripherals property

The value of this property is a bitfield that lists the peripherals supported by the bootloader and the hardware on which it is running.

**Table 138. Peripheral Bits**

| Bit   | [31:7]   | [6]      | [5]      | [4]     | [3]      | [2]       | [1]       | [0]    |
|-------|----------|----------|----------|---------|----------|-----------|-----------|--------|
| Field | Reserved | Reserved | Reserved | USB HID | Reserved | SPI Slave | I2C Slave | LPUART |

If the peripheral is available, then the corresponding bit will be set in the property value. All reserved bits must be set to 0.

### 20.5.9.3 AvailableCommands property

This property value is a bitfield with set bits indicating the commands enabled in the bootloader. Only commands that can be sent from the host to the target are listed in the bitfield. Response commands such as GenericResponse are excluded.

The bit number that identifies whether a command is present is the command's tag value minus 1. 1 is subtracted from the command tag because the lowest command tag value is 0x01. To get the bit mask for a given command, use this expression: mask = 1 << (tag - 1).

**Table 139. Command Bits**

| Bit     | [Others] | [20]     | [16]     | [15]     | [14]     | [13]     | [12]     | [11]        | [10]  | [9]      | [8]     | [7]      | [6]         | [5]      | [4]        | [3]         | [2]        | [1]              | [0]           |
|---------|----------|----------|----------|----------|----------|----------|----------|-------------|-------|----------|---------|----------|-------------|----------|------------|-------------|------------|------------------|---------------|
| Command | Reserved | SetProperty | Reset | Reserved | Execute | Reserved | GetProperty | Reserved | FillMemory | WriteMemory | ReadMemory | FlashEraseRegion | FlashEraseAll |

### 20.5.10 Serial Boot on USB path

The bootloader supports In-System Programming using the USB peripheral. The target is implemented as USB-HID device classes.

When transfer data through USB-HID device class, USB-HID does not use framing packets. Instead, the packetization, inherent in the USB protocol itself is used. The ability for the device to NAK Out transfers (until they can be received) provides the required flow control. The built-in CRC of each USB packet provides the required error detection

#### 20.5.10.1 Device descriptor

The bootloader configures the default USB VID/PID/Strings as below:

Default VID/PID:

- VID = 0x1FC9.
- PID = 0x0155.

Default Strings:

- Manufacturer [1] = "NXP SEMICONDUCTOR INC".
- Product [2] = "USB COMPOSITE DEVICE".

The USB VID, PID, and Strings can be customized using the CMPA of the flash. For example, the USB VID and PID can be customized by writing the new VID to the usbVid field and the new PID to the usbPid field of the CMPA in flash.

#### 20.5.10.2 Endpoints

The HID peripheral uses three endpoints:

- Control (0)
- Interrupt IN (1)
- Interrupt OUT (2)

The Interrupt OUT endpoint is optional for HID class devices, but the MCU bootloader uses it as a pipe, where the firmware can NAK send requests from the USB host.

#### 20.5.10.3 HID Reports

There are four HID reports defined and used by the bootloader USB HID peripheral. The report ID determines the direction and type of packet sent in the report; otherwise, the contents of all reports are the same.

Table 140. HID reports assigned for the bootloader

| Report ID | Packet Type | Direction |
|-----------|-------------|-----------|
| 1         | Command     | OUT       |
| 2         | Data        | OUT       |
| 3         | Command     | IN        |
| 4         | Data        | IN        |

Each report has a maximum size of 60 bytes. The maximum payload size is 56 bytes. In addition, there is a 4-byte report header that indicates the length (in bytes) of the payload and report id sent the packet.

**Note:** In the future, the maximum report size may be increased, to support transfers of larger packets. Alternatively, additional reports may be added with larger maximum sizes.

The actual data sent in all of the reports looks like:

Table 141. Data format sent in USB HID packet

|       | Data format       |
|-------|-------------------|
| 0     | Report ID         |
| 1     | Padding           |
| 2     | Packet Length LSB |
| 3     | Packet Length MSB |
| 4     | Packet[0]         |
| 5     | Packet[1]         |
| 6     | Packet[2]         |
|       | ...               |
| N+4-1 | Packet[N-1]       |

This data includes the Report ID, which is required if more than one report is defined in the HID report descriptor. The actual data sent and received has a maximum length of 35 bytes. The Packet Length header is written in little-endian format, and it is set to the size (in bytes) of the packet sent in the report. This size does not include the Report ID or the Packet Length header itself. During a data phase, a packet size of 0 indicates a data phase abort request from the receiver.

### 20.5.11 Serial Boot on LPUART path

The bootloader integrates an autobaud detection algorithm for the UART peripheral, thereby providing flexible baud rate choices.

**Autobaud feature:** If  $\text{UART}_n$  is used to connect to the bootloader, then the  $\text{UART}_n\text{-RX}$  pin must be kept high and not left floating during the detection phase in order to comply with the autobaud detection algorithm. After the bootloader detects the Ping packet (0x5A 0xA6) on  $\text{UART}_n\text{-RX}$ , the bootloader firmware executes the autobaud sequence.

If the baudrate is successfully detected, then the bootloader sends a Ping packet response [(0x5A 0xA7), protocol version (4 bytes), protocol version options (2 bytes) and crc16 (2 bytes)] at the detected baudrate. The bootloader then enters a loop, waiting for bootloader commands via the UART peripheral.

#### NOTE

The data bytes of the ping packet must be sent continuously (with no more than 80 ms between bytes) in a fixed UART transmission mode (8-bit data, no parity bit and 1 stop bit). If the bytes of the ping packet are sent one-by-one with more than 80 ms delay between them, then the autobaud detection algorithm may calculate an incorrect baud rate. In this instance, the autobaud detection state machine should be reset.

**Supported baud rates:** The baud rate is closely related to the MCU core and system clock frequencies. Typical baud rates supported are 9600, 19200, 38400, 57600, 115200, 230400 and 460800.

**Packet transfer:** After autobaud detection succeeds, bootloader communications can take place over the UART peripheral. The following flow charts show:

- How the host detects an ACK from the target.
- How the host detects a ping response from the target.
- How the host detects a command response from the target.



Figure 43. Host Reads Ping Packet form Target via LPUART



Figure 44. Host Read ACK from Target via LPUART



### 20.5.12 Extended Bootloader API

### 20.5.13 Bootloader Status Error Codes

This section describes the status error codes that the Bootloader returns to the host.

Table 142. Bootloader Status Error Codes, Sorted by Value

| Error Code                   | Value | Description                                                |
|------------------------------|-------|------------------------------------------------------------|
| kStatus_Success              | 0     | Operation succeeded without error.                         |
| kStatus_Success              | 0     | Operation succeeded without error.                         |
| kStatus_Fail                 | 1     | The operation failed with a generic error.                 |
| kStatus_ReadOnly             | 2     | Requested value cannot be changed because it is read-only. |
| kStatus_OutOfRange           | 3     | Requested value is out of range.                           |
| kStatus_InvalidArgument      | 4     | The requested command's argument is undefined.             |
| kStatus_Timeout              | 5     | A timeout occurred.                                        |
| kStatus_NoTransferInProgress | 6     | No send in progress                                        |
| kStatus_FLASH_Success        | 0     | API is executed successfully                               |

*Table continues on the next page...*

Table 142. Bootloader Status Error Codes, Sorted by Value (continued)

| Error Code                                 | Value | Description                                                   |
|--------------------------------------------|-------|---------------------------------------------------------------|
| kStatus_FLASH_InvalidArgument              | 4     | An invalid argument is provided                               |
| kStatus_FlashSizeError                     | 100   | Not used.                                                     |
| kStatus_FlashAlignmentError                | 101   | Address or length does not meet the required alignment.       |
| kStatus_FlashAddressError                  | 102   | Address or length is outside addressable memory.              |
| kStatus_FlashAccessError                   | 103   | The FTFA_FSTAT[ACCERR] bit is set.                            |
| kStatus_FlashProtectionViolation           | 104   | The FTFA_FSTAT[FPPVIOL] bit is set.                           |
| kStatus_FlashCommandFailure                | 105   | The FTFA_FSTAT[MGSTAT0] bit is set.                           |
| kStatus_FlashUnknownProperty               | 106   | Unknown Flash property.                                       |
| kStatus_FlashEraseKeyError                 | 107   | The key provided does not match the programmed flash key.     |
| kStatus_FlashRegionExecuteOnly             | 108   | The area of flash is protected as execute-only.               |
| kStatus_FLASH_ExecuteInRamFunctionNotReady | 109   | Execute-in-RAM function is not available                      |
| kStatus_FLASH_CommandNotSupported          | 111   | Flash API is not supported                                    |
| kStatus_FLASH_ReadOnlyProperty             | 112   | The flash property is read-only                               |
| kStatus_FLASH_InvalidPropertyValue         | 113   | The flash property value is out of range                      |
| kStatus_FLASH_InvalidSpeculationOption     | 114   | The option of flash prefetch speculation is invalid           |
| kStatus_FLASH_EccError                     | 116   | A correctable or uncorrectable error during command execution |
| kStatus_FLASH_CompareError                 | 117   | Destination and source memory contents do not match           |
| kStatus_FLASH_RegulationLoss               | 118   | A loss of regulation during read                              |
| kStatus_FLASH_InvalidWaitStateCycles       | 119   | The wait state cycle set to r/w mode is invalid               |
| kStatus_FLASH_OutOfDateCfpapage            | 132   | CFPA page version is out of date                              |
| kStatus_FLASH_BanklfrPageData              | 133   | Blank page cannot be read                                     |

*Table continues on the next page...*

Table 142. Bootloader Status Error Codes, Sorted by Value (continued)

| Error Code                                       | Value | Description                                                         |
|--------------------------------------------------|-------|---------------------------------------------------------------------|
| kStatus_FLASH_EncryptedRegionsEraseNotDoneAtOnce | 134   | Encrypted flash subregions are not erased at once                   |
| kStatus_FLASH_ProgramVerificationNotAllowed      | 135   | Program verification is not allowed when the encryption is enabled  |
| kStatus_FLASH_HashCheckError                     | 136   | Hash check of page data is failed                                   |
| kStatus_FLASH_SealedFfrRegion                    | 137   | The FFR region is sealed                                            |
| kStatus_FLASH_FfrRegionWriteBroken               | 138   | The FFR Spec region is not allowed to be written discontinuously    |
| kStatus_FLASH_NmpaAccessNotAllowed               | 139   | The NMPA region is not allowed to be read/written/erased            |
| kStatus_FLASH_CmpaCfgDirectEraseNotAllowed       | 140   | The CMPA Cfg region is not allowed to be erased directly            |
| kStatus_FLASH_FfrBankIsLocked                    | 141   | The FFR bank region is locked                                       |
| kStatus_FLASH_CfpScratchPageInvalid              | 148   | CFPA Scratch Page is invalid                                        |
| kStatus_FLASH_CfpVersionRollbackDisallowed       | 149   | CFPA version rollback is not allowed                                |
| kStatus_FLASH_ReadHidingAreaDisallowed           | 150   | Flash hiding read is not allowed                                    |
| kStatus_FLASH_ModifyProtectedAreaDisallowed      | 151   | Flash firewall page locked erase and program are not allowed        |
| kStatus_FLASH_CommandOperationInProgress         | 152   | The flash state is busy, indicate that a flash command in progress. |
| kStatus_UnknownCommand                           | 10000 | this command is not recognized                                      |
| kStatus_SecurityViolation                        | 10001 | Security Violation happened when receiving disallowed commands      |
| kStatus_AbortDataPhase                           | 10002 | Sender requested data phase abort                                   |
| kStatus_Ping                                     | 10003 | Ping Command Received from the host                                 |
| kStatus_NoResponse                               | 10004 | No Response from the host                                           |
| kStatus_NoResponseExpected                       | 10005 | Expected No Response from the host                                  |
| kStatus_CommandUnsupported                       | 10006 | Unsupported command was received                                    |
| kStatusRomLdrSectionOverrun                      | 10100 | means reached the end of the sb file processing                     |

*Table continues on the next page...*

Table 142. Bootloader Status Error Codes, Sorted by Value (continued)

| Error Code                          | Value | Description                                                                            |
|-------------------------------------|-------|----------------------------------------------------------------------------------------|
| kStatusRomLdrSignature              | 10101 | the signature or version are incorrect                                                 |
| kStatusRomLdrSectionLength          | 10102 | the bootOffset/ new section count is out of range                                      |
| kStatusRomLdrUnencryptedOnly        | 10103 | the unencrypted image is disabled                                                      |
| kStatusRomLdrEOFReached             | 10104 | the end of the image file is reached                                                   |
| kStatusRomLdrChecksum               | 10105 | The checksum of a command tag block is invalid.                                        |
| kStatusRomLdrCrc32Error             | 10106 | The CRC-32 of the data for a load command is incorrect.                                |
| kStatusRomLdrUnknownCommand         | 10107 | An unknown command was found in the SB file.                                           |
| kStatusRomLdrIdNotFound             | 10108 | There was no bootable section found in the SB file.                                    |
| kStatusRomLdrDataUnderrun           | 10109 | The SB state machine is waiting for more data.                                         |
| kStatusRomLdrJumpReturned           | 10110 | The function that was jumped to by the SB file has returned.                           |
| kStatusRomLdrCallFailed             | 10111 | The call command in the SB file failed.                                                |
| kStatusRomLdrKeyNotFound            | 10112 | A matching key was not found in the SB file's key dictionary to unencrypt the section. |
| kStatusRomLdrSecureOnly             | 10113 | The SB file sent is unencrypted, and security on the target is enabled.                |
| kStatusRomLdrResetReturned          | 10114 | The SB file reset operation has unexpectedly returned.                                 |
| kStatusRomLdrRollbackBlocked        | 10115 | An Image version rollback event detected                                               |
| kStatusRomLdrInvalidSectionMacCount | 10116 | Invalid Section MAC count detected in the SB file                                      |
| kStatusRomLdrUnexpectedCommand      | 10117 | The command tag in the sb-file is unexpected                                           |
| kStatusRomLdrBadSBKEK               | 10118 | Bad SBKEK detected                                                                     |

*Table continues on the next page...*

Table 142. Bootloader Status Error Codes, Sorted by Value (continued)

| Error Code                               | Value | Description                                                                                                       |
|------------------------------------------|-------|-------------------------------------------------------------------------------------------------------------------|
| kStatusRomLdrPendingJumpCommand          | 10119 | Represent the jump command is pending and the actual jump is implemented in sbloader_finalize()                   |
| kStatusMemoryRangeInvalid                | 10200 | The requested address range does not match an entry, or the length extends past the matching entry's end address. |
| kStatusMemoryReadFailed                  | 10201 | Memory Read Failed                                                                                                |
| kStatusMemoryWriteFailed                 | 10202 | Memory Write failed                                                                                               |
| kStatusMemoryCumulativeWrite             | 10203 | Cumulative Write happened due to write to un-erased FLASH region                                                  |
| kStatusMemoryNotConfigured               | 10205 | Memory is not configured yet before access                                                                        |
| kStatusMemoryAlignmentError              | 10206 | Alignment Error happened during access to memory                                                                  |
| kStatusMemoryVerifyFailed                | 10207 | Verifying operation failed after erasing/programming FLASH                                                        |
| kStatusMemoryWriteProtected              | 10208 | The memory to be written is protected                                                                             |
| kStatusMemoryAddressError                | 10209 | The Memory address is invalid/wrong                                                                               |
| kStatusMemoryBlankCheckFailed            | 10210 | Check the blank memory failed                                                                                     |
| kStatusMemoryBlankPageReadDisallowed     | 10211 | The memory is blank, and read command is disallowed                                                               |
| kStatusMemoryProtectedPageReadDisallowed | 10212 | The memory is protected, and read command is disallowed                                                           |
| kStatusMemoryFfrSpecRegionWriteBroken    | 10213 | The write operation to the FFR Region was broken                                                                  |
| kStatusMemoryUnsupportedCommand          | 10214 | The memory command is not supported                                                                               |
| kStatus_UnknownProperty                  | 10300 | The requested property value is undefined.                                                                        |
| kStatus_ReadOnlyProperty                 | 10301 | The requested property value cannot be written.                                                                   |
| kStatus_InvalidPropertyValue             | 10302 | The specified property value is invalid.                                                                          |
| kStatus_AppCrcCheckPassed                | 10400 | CRC check is valid and passed.                                                                                    |
| kStatus_AppCrcCheckFailed                | 10401 | CRC check is valid but failed.                                                                                    |

*Table continues on the next page...*

Table 142. Bootloader Status Error Codes, Sorted by Value (continued)

| Error Code                                  | Value | Description                                                                                        |
|---------------------------------------------|-------|----------------------------------------------------------------------------------------------------|
| kStatus_AppCrcCheckInactive                 | 10402 | CRC check is inactive.                                                                             |
| kStatus_AppCrcCheckInvalid                  | 10403 | CRC check is invalid because the BCA is invalid, or the CRC parameters are unset (all 0xFF bytes). |
| kStatus_AppCrcCheckOutOfRange               | 10404 | CRC check is valid, but addresses are out of range.                                                |
| kStatus_RomApiExecuteCompleted              | 0     | ROM successfully process the whole sb file/boot image                                              |
| kStatus_RomApiNeedMoreData                  | 10801 | ROM needs more data to continue processing the boot image                                          |
| kStatus_RomApiBufferSizeNotEnough           | 10802 | The user buffer is not enough for use by Kboot during execution of the operation                   |
| kStatus_RomApiInvalidBuffer                 | 10803 | The user buffer is not ok for sbloader or authentication                                           |
| kStatus_FLEXSPI_SequenceExecutionTimeout    | 6000  | The FLEXSPI Sequence Execution timeout                                                             |
| kStatus_FLEXSPI_InvalidSequence             | 6001  | The FLEXSPI LUT sequence invalid                                                                   |
| kStatus_FLEXSPI_DeviceTimeout               | 6002  | The FLEXSPI device timeout                                                                         |
| kStatus_FLEXSPINOR_ProgramFail              | 20100 | Page programming failure                                                                           |
| kStatus_FLEXSPINOR_EraseSectorFail          | 20101 | Sector Erase failure                                                                               |
| kStatus_FLEXSPINOR_EraseAllFail             | 20102 | Chip Erase failure                                                                                 |
| kStatus_FLEXSPINOR_WaitTimeout              | 20103 | The execution time out                                                                             |
| kStatus_FlexSPINOR_NotSupported             | 20104 | Page size overflow                                                                                 |
| kStatus_FlexSPINOR_WriteAlignmentError      | 20105 | Address alignment error                                                                            |
| kStatus_FlexSPINOR_CommandFailure           | 20106 | Erase/Program Verify Error                                                                         |
| kStatus_FlexSPINOR_SFDP_NotFound            | 20107 | Timeout occurs during the API call                                                                 |
| kStatus_FLEXSPINOR_Unsupported_SFDP_Version | 20108 | Unrecognized SFDP version                                                                          |
| kStatus_FLEXSPINOR_FLASH_NotFound           | 20109 | Flash detection failure                                                                            |

*Table continues on the next page...*

Table 142. Bootloader Status Error Codes, Sorted by Value (continued)

| Error Code                                  | Value  | Description                                                                                       |
|---------------------------------------------|--------|---------------------------------------------------------------------------------------------------|
| kStatus_FLEXSPINOR_DTRRead_DummyProbeFailed | 20110  | DDR Read dummy probe failure                                                                      |
| kStatus_IAP_Success                         | 0      | IAP API execution succeeded                                                                       |
| kStatus_IAP_Fail                            | 1      | IAP API execution failed                                                                          |
| kStatus_IAP_InvalidArgument                 | 100001 | Invalid argument detected during API execution                                                    |
| kStatus_IAP_OutOfMemory                     | 100002 | The Heap size is not enough during API execution                                                  |
| kStatus_IAP_ReadDisallowed                  | 100003 | The read memory operation is disallowed during API execution                                      |
| kStatus_IAP_CumulativeWrite                 | 100004 | The FLASH region to be programmed is not empty                                                    |
| kStatus_IAP_EraseFailure                    | 100005 | Erase operation failed                                                                            |
| kStatus_IAP_CommandNotSupported             | 100006 | The specific command is not supported                                                             |
| kStatus_IAP_MemoryAccessDisabled            | 100007 | Memory access is disabled, typically occurred on the FLEXSPI NOR if it is not configured properly |

# Chapter 21

## Clocking

### 21.1 Introduction

The main component of the clocking architecture is the System Clock Generator (SCG) module. The SCG controls multiple clock sources that are distributed to the main CPU platform, the memory modules and the peripheral modules. The peripheral modules have an *interface* clock that is used by the CPU/DMA to interface with each module's registers. When applicable, modules may also have *functional* clocks to provide the main timing function of the module's application. For example, functional clocks can be used to source the baud rate for a serial communications peripheral or to clock the counter of a timer peripheral.

The SCG controls the on chip clock sources, including 40MHz OSC, FRO192M and FRO12M. It also generates the clock sources for peripherals functional clock. A clock mux is implemented in SCG-Lite to select the clock source for main\_clk.

The MAIN\_CLK can be sourced directly from the following:

- FRO192M (It has a 48 MHz output, which is used as USB clock)
- FRO12M
- FRO16k
- 40 MHz OSC-SYS

Auto-trimming function is implemented for FRO192M. The trim source includes USB FS, SOF, SOSC. When auto-trimming is enabled, FRO192M can achieve +0.25% accuracy. Clock monitor is implemented for SOSC. When enabled, SOSC clock is monitored by FRO12M. 1 MHz clock is derived from FRO12M, and is always on in active and sleep mode.

### 21.2 Configure main clock and system clock

The clock source for the registers and memories is derived from main clock. The main clock can be selected from the sources listed in step 1 below.

The CPU\_CLK derived from MAIN\_CLK, also called the system clock, clocks the core, the memories, and the peripherals (register interfaces and peripheral clocks).

1. Select the main clock in the SCG\_RCCR register. The following options are available:
  - FRO 12 MHz output (FRO\_12M) from internal oscillator.
  - FRO 16 kHz output (FRO\_16k)
  - FRO high speed output (fro\_hf) from FRO192M. By default, it is 48 MHz. fro\_hf is the default main clock.
  - 40 MHz SYS-OSC
2. Select the divider value for the system clock in System Clock Divider (AHBCLKDIV) register in the System Controller module.
3. Enable the clock for the memories and peripherals used in the application.
4. Peripheral clock must be disabled registers in SYSCON module when performing software reset on the peripherals (registers in SYSCON). Once reset assertion and de-assertion are completed, the respective peripheral clock can be enabled.

### 21.3 Clock generation

The system control block facilitates the clock generation. Many clocking variations are possible. [Module clocking](#) gives an overview of potential clock options. [Table 143](#) describes signals on the clocking diagram. The maximum clock frequency is 96 MHz.

**NOTE**

The indicated clock multiplexers shown in [Module clocking](#) are synchronized. In order to operate, the currently selected clock must be running, and the clock to be switched to must also be running so the multiplexer can gracefully switch between the two clocks without glitches. Other clock multiplexers are not synchronized. The output divider can be stopped and restarted gracefully during switching if a glitch-free output is needed.

The FRO\_12M provides a 1 MHz clock (clk\_1m). It is used as Watchdog 0 independent clock source. The accuracy of this clock is limited to a couple percent over temperature (see Data sheet for specification), voltage, and silicon processing variations after trimming made during assembly. To determine the actual Watchdog oscillator output, use the frequency measure block. See [Chip-specific FREQME information](#).

**NOTE**

The maximum allowed frequency for the main clock and system clock (to CPU0, AHB bus, Sync, etc.) is 96 MHz.

**Table 143. Clocking diagram signal name descriptions**

| Name <sup>1</sup>     | Description                                                                                                                                                            |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| clk_16k[0]/clk_16k[1] | It is the 16.384 KHz clock output from FRO16K. It is the clock of peripherals in VSYS domain.                                                                          |
| clk_in                | It is the internal clock that comes from the external oscillator.                                                                                                      |
| fro_hf                | It is the clock output from FRO192M. The frequency is controlled by SCG_FIRCCFG[FREQ_SEL].                                                                             |
| fro_hf_div            | It is the clock divided by fro_hf                                                                                                                                      |
| clk_48M               | It is the 48 MHz clock output from FRO192M                                                                                                                             |
| fro_12M               | It is the 12 MHz clock output from FRO12M                                                                                                                              |
| clk_1M                | It is the 1 MHz clock output from FRO12M                                                                                                                               |
| main_clk              | It is main clock used by the CPU, AHB bus, APB bus, IPS bus, and some peripherals.<br>The main clock and its source selection are shown in <a href="#">Figure 48</a> . |
| CPU_CLK               | It is the clock of CPU.                                                                                                                                                |
| SYSTEM_CLK            | It is the clock of AHB bus, APB bus, IPS bus. The frequency is same with CPU_CLK                                                                                       |
| SLOW_CLK              | It is the SYSTEM_CLK divided by 4                                                                                                                                      |

- See the clock frequency table for max frequencies of each of these clocks.

**Table 144. Clock frequency table**

| Clock Name             | Max. Clock Frequency        |            |
|------------------------|-----------------------------|------------|
|                        | MD mode                     | SD mode    |
| clk_16k[0]/ clk_16k[1] | 16.384 KHz                  | 16.384 KHz |
| clk_in                 | SOSC OFF 50 MHz bypass mode | 50 MHz     |
| fro_hf                 | 96 MHz                      | 192 MHz    |
| fro_hf_div             | 48 MHz                      | 96 MHz     |

*Table continues on the next page...*

Table 144. Clock frequency table (continued)

| Clock Name | Max. Clock Frequency |         |
|------------|----------------------|---------|
|            | MD mode              | SD mode |
| clk_48M    | 48 MHz               | 48 MHz  |
| fro_12M    | 12 MHz               | 12 MHz  |
| clk_1M     | 1 MHz                | 1 MHz   |
| main_clk   | 96 MHz               | 192 MHz |
| CPU_CLK    | 48 MHz               | 96 MHz  |
| SYSTEM_CLK | 48 MHz               | 96 MHz  |
| SLOW_CLK   | 12 MHz               | 24 MHz  |

### 21.3.1 Peripheral bus clock

The following peripherals use SLOW\_CLK as APB/IPS clock. All other peripherals use SYSTEM\_CLK as APB/IPS clock.

- LPTMR0
- CMP0
- Wake Timer
- AOI
- CMC
- SCG-Lite
- SPC
- WUU
- FMU

### 21.3.2 Peripheral clock summary

| Modules                | Max Functional Clock in MD mode | Max Functional Clock in SD mode |
|------------------------|---------------------------------|---------------------------------|
| CPU and system modules |                                 |                                 |
| Systick Clock          | 12MHz                           | 24MHz                           |
| WWDT0 Clock            | 1MHz                            | 1MHz                            |
| Trace Clock            | 48MHz                           | 96MHz                           |
| Communication Modules  |                                 |                                 |
| LPUART0~2 Clock        | 48MHz                           | 96MHz                           |
| LP SPI0~1 Clock        | 48MHz                           | 96MHz                           |
| LPI2C0 Clock           | 24MHz                           | 48MHz                           |
| I3C0 Clock             | 25MHz                           | 25MHz                           |
| USB FS Clock           | 48MHz                           | 48MHz                           |

*Table continues on the next page...*

*Table continued from the previous page...*

| Timer Modules  |           |           |
|----------------|-----------|-----------|
| LPTMR0 Clock   | 12MHz     | 24MHz     |
| PWM0           | 96MHz     | 192MHz    |
| Quad Decoder   | 48MHz     | 96MHz     |
| Ctimer 0~2     | 96MHz     | 192MHz    |
| Ostimer Clock  | 1MHz      | 1MHz      |
| uTimer Clock   | 1MHz      | 1MHz      |
| Analog Modules |           |           |
| ADC0           | 24MHz     | 64MHz     |
| CMP0/1         | 24MHz     | 24MHz     |
|                |           |           |
| MISC Modules   |           |           |
| Wake Timer     | 16.384KHz | 16.384KHz |
| VBAT Clock     | 16.384KHz | 16.384KHz |

---

#### NOTE

It is the max. clock frequency of the modules in clock diagrams under different run mode

---

### 21.3.3 Module clocking

The following figures show the clock generation diagrams of the device's modules.



Figure 46. SCG clock



Figure 47. VBAT clock



Figure 48. Main CPU clock

**Figure 49. Clock Divider clock****Figure 50. ADC clock****Figure 51. Trace clock**

**Figure 52. CMP0 clock****Figure 53. CMP1 clock****Figure 54. WWDT clock**



Figure 55. Systick clock



Figure 56. FRO HF clock



Figure 57. LPUART clock



Figure 58. LPI2C clock



Figure 59. LPSPI clock



Figure 60. LPTMR clock



Figure 61. CTimer clock



Figure 62. I3C clock

Figure 63. WUU clock



Figure 64. eFlexPWM clock



Figure 65. QDC clock



Figure 66. CMC clock



Figure 67. UTICK clock



Figure 68. OSTimer clock





aaa-047991

Figure 69. USB FS clock

# Chapter 22

## System Clock Generator (SCG)

### 22.1 Chip-specific SCG information

Table 145. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | SCG            | <a href="#">SCG</a>                 |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 22.1.1 Module instances

This device contains one instance of the SCG module, SCG0.

#### 22.1.2 Crystal oscillator clock sources

In this device, the ROSC is sourced from Crystal Oscillator FRO16K clock in VBAT block.

#### 22.1.3 Clock decoder ring

The table below shows translation of clock name sources used in the SCG chapter to the names used throughout the document.

Table 146. Clock name decoder ring

| Clock source specified in chapter | Decoded clock name |
|-----------------------------------|--------------------|
| SOSC                              | CLK_IN             |
| SIRC                              | FRO_12M            |
| FIRC                              | FRO_HF             |
| ROSC                              | FRO_16K            |
| UPLL                              | CLK_48M            |

#### NOTE

FRO144M is not supported on this device.

### 22.2 Overview

The System Clock Generator (SCG) module provides the main clock and other peripheral clocks for the MCU. The SCG takes clock inputs from a variety of sources and generates the clocks that the MCU requires.



The clock source inputs available for the SCG are as follows:

- System oscillator clock (SOSC)
- Slow internal reference clock (SIRC)
- Fast internal reference clock (FIRC)
- Real-Time oscillator clock (ROSC)

### 22.2.1 Block diagram



### 22.2.2 Features

Key features of the SCG module are:

- 2 Internal Reference Clock (IRC) generators
  - FIRC with trim capability
  - FIRC can output 192/96/64/48 MHz clock by register configuration
  - FIRC can limit output frequency by frequency phantom
  - FIRC can output 48 MHz clock continuously
  - SIRC with trim capability
  - SIRC can output 12 MHz clock and 1 MHz clock divided from it
  - Either of the IRC generators can be selected as the clock source for the system clocks
- System Crystal Oscillator Clock (SOSC)
  - Can be selected as the clock source for system clocks
- Real Time Oscillator Clock (ROSC)
  - Can be selected as the clock source for the device. See the Clocking chapter to ascertain which signal the ROSC input maps to.
- Clock monitor with reset and interrupt request capability for SOSC clocks

## 22.3 Functional description

### 22.3.1 SCG clock mode transitions

The system boots up from the FIRC source. The system clock can be switched among the following clock sources: FIRC, SIRC, SOSC, ROSC.

The SCG restricts programming into invalid clock modes, and ignores writes to the System Clock Source (SCS) bits. When a transition between run modes or a transition from run mode into wait mode occurs, the SCG completes the switch to the corresponding clock mode as defined in the Run Clock Control Register (RCCR). After that, the system switches to the selected run/wait mode.

The following table describes the modes of operation of the SCG.

Table 147. SCG modes of operation

| Mode | Description                                                                                                                                                                                                                                                                                                         |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SOSC | <p>The SOSC mode is entered when the following occur:</p> <ul style="list-style-type: none"> <li>• the device is in run mode and 001 is written to RCCR[SCS]</li> <li>• SOSCCSR[SOSCEN] = 1b</li> <li>• SOSCCSR[SOSCVLD] = 1b</li> </ul> <p>In SOSC mode, the system clocks are derived from the external SOSC.</p> |
| SIRC | <p>The SIRC mode is entered when the following occur:</p> <ul style="list-style-type: none"> <li>• the device is in run mode and 010 is written to RCCR[SCS]</li> <li>• SIRCCSR[SIRCVLD] = 1b</li> </ul> <p>In SIRC mode, the system clocks are derived from SIRC.</p>                                              |
| FIRC | The FIRC mode is the default clock mode of operation or it is entered when the following occur:                                                                                                                                                                                                                     |

*Table continues on the next page...*

Table 147. SCG modes of operation (continued)

| Mode | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | <ul style="list-style-type: none"> <li>the device is in run mode and 011 is written to RCCR[SCS]</li> <li>FIRCCSR[FIRCEN] = 1b</li> <li>FIRCCSR[FIRCVLD] = 1b</li> </ul> <p>In FIRC mode, the system clocks are derived from FIRC. Eight frequency settings are available for FIRC clock as described in FIRCCFG[FREQ_SEL]. The changes to FIRC frequency settings are ignored when the FIRC clock is enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| ROSC | <p>The ROSC mode is entered when the following occur:</p> <ul style="list-style-type: none"> <li>the device is in run mode and 100 is written to RCCR[SCS]</li> <li>ROSCCSR[ROSCVLD] = 1b</li> </ul> <p>In ROSC mode, the systems clocks are derived from the external ROSC.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Stop | <p>The Stop mode is entered whenever the MCU enters a Stop state. Power modes are chip-specific. For power mode assignments, see Power Management chapter that describes module operation in low-power modes. Entering Stop mode, all SCG clock signals are static, including SCG system clocks.</p> <p>There are some exceptions. The following clocks can continue to run and stay enabled when all the specific conditions are true.</p> <p>SIRC is available in Deep Sleep mode when all the following conditions are true:</p> <ul style="list-style-type: none"> <li>SIRCCSR[SIRCSTEN] = 1b</li> </ul> <p>FIRC is available in Deep Sleep mode when all the following conditions are true:</p> <ul style="list-style-type: none"> <li>FIRCCSR[FIRCEN] = 1b</li> <li>FIRCCSR[FIRCSTEN] = 1b</li> </ul> <p>SOSC is available in Deep Sleep mode when all the following conditions are true.</p> <ul style="list-style-type: none"> <li>SOSCCSR[SOSCEN] = 1b</li> <li>SOSCCSR[SOSCSTEN] = 1b</li> </ul> |

### 22.3.2 SCG SOSC operation

The following table lists the SOSC configurations and SOSC output clock.

Table 148. SOSC mode operation

| SOSCEN | EREFs | SOSC clock               |
|--------|-------|--------------------------|
| 0      | 0     | Off                      |
| 1      | 0     | EXTAL Pad Clock          |
| 1      | 1     | Crystal Oscillator Clock |

### 22.3.3 SCG LOC operation

The SCG supports the loss of clock (LOC) monitoring for the external reference clocks including SOSC reference clock. To enable the LOC monitor, the CME bit for the clock must be programmed to 1. To monitor the external reference clock, the SCG uses

an internal 31.25 KHz reference clock derived by dividing the SIRC internal clock. So prior to enabling the LOC for the external reference clock, it is required that the SIRC is programmed to be enabled.

The LOC monitors, when enabled, generate a system reset or system interrupt request depending on the settings of the CMRE (see the CMRE description for each of the clocks for further information). The frequency conditions for the external reference clocks that trigger a LOC event are listed below:

---

#### NOTE

$F_{int}$  = SIRC divided down to 31.25 kHz

---

- SOSC loss of external clock minimum frequency
  - When SOSC clock frequency is above  $(16/5) F_{int}$ , the chip is never reset or generate an interrupt.
  - When SOSC clock frequency is between  $(15/5) F_{int}$  and  $(16/5) F_{int}$ , the chip might reset or generate an interrupt (depending on the phase dependency between SOSC clock and reference clock)
  - When SOSC clock frequency is below  $(15/5) F_{int}$ , the chip always resets or generates an interrupt.

### 22.3.4 Clocking

The SCG module has the following input clocks:

- Bus clock for register access.
- ROSC clocks as one of the system clock sources

The SCG module has the following output clocks:

- Main clock
- FIRC clock (192/96/64/48 MHz)
- SIRC clock (12 MHz and 1 MHz divided from it)
- SOSC clock

### 22.3.5 Resets

These are the SCG resets:

1. The global reset is fed into this module. The entire module is reset by the global reset.
2. The clock monitor generates a reset in case of the following:
  - $SOSCCSR[SOSCCM] = 1 \& SOSCCSR[SOSCCMRE] = 1 \& SOSCCSR[SOSCERR] = 1$

On the assertion of any reset source, the FIRC 48 MHz clock is enabled or starts up if not running.

### 22.3.6 Interrupts

These are the SCG interrupts:

- Clock monitor generates interrupt when any of below happens:
  - $SOSCCSR[SOSCCM] = 1 \& SOSCCSR[SOSCCMRE] = 0 \& SOSCCSR[SOSCERR] = 1$
- Interrupt can also be generated when any of below happens:
  - SOSC clock source is not valid.  $SOSCCSR[SOSCVLD\_IE] = 1 \& SOSCCSR[SOSCVLD] = 1$
  - FIRC clock source is not accurate.  $FIRCCSR[FIRCACC\_IE] = 1 \& FIRCCSR[FIRCACC] = 1$
  - FIRC trimming error detected.  $FIRCCSR[FIRCERR\_IE] = 1 \& FIRCCSR[FIRCERR] = 1$
  - SIRC trimming error detected.  $SIRCCSR[SIRCERR\_IE] = 1 \& SIRCCSR[SIRCERR] = 1$

## 22.4 External signals

Table 149. External signal descriptions

| Signal | Description             | Mode | I/O |
|--------|-------------------------|------|-----|
| XTAL   | SOSC Crystal output pin | SOSC | O   |
| EXTAL  | SOSC Crystal input pin  | SOSC | I   |
| CLKOUT | SCG clock output pin    | SCG  | O   |

## 22.5 Initialization

Out of reset, the FIRC is default enabled. FIRCCFG[FREQ\_SEL] is set to 001b, and RCCR[SCS] is set to 011b, so the FRO\_HF clock which is set to 48 MHz would be as the system clock source.

Out of reset, the SIRC is default enabled.

Out of reset, all the other clock sources are disabled.

## 22.6 Application information

### 22.6.1 SOSC configuration example

1. Write 1 to SOSCCFG[EREFS] to select SOSC source (internal crystal oscillator)
2. Write 0 to SOSCCFG[RANGE] to configure SOSC range
3. Write 0 to SOSCCSR[LK] to unlock SOSCCSR
4. Write 1 to SOSCCSR[SOSCCM] to enable SOSC clock monitor
5. Write 1 to SOSCCSR[SOSCSTEN] to enable SOSC in Deep Sleep mode if needed
6. Write 1 to SOSCCSR[SOSCEN] to enable SOSC
7. Read SOSCCSR[SOSCVLD] until it returns 1, indicating SOSC is valid
8. Read SOSCCSR[SOSCERR] to ensure it returns 0
9. Write 1 to RCCR[SCS] to switch main clock to SOSC
10. Read CSR[SCS] until it returns 1, indicating the switch is complete

### 22.6.2 SIRC configuration example

#### 22.6.2.1 SIRC normal configuration example

1. Write 0 to SIRCCSR[LK] to unlock SIRCCSR
2. Write 1 to SIRCCSR[SIRCSTEN] to enable SIRC in Deep Sleep mode, if needed
3. Write 1 to SIRCCSR[SIRC\_CLK\_PERIPH\_EN] to enable SIRC clock for peripheral use
4. Read SIRCCSR[SIRCVLD] until it returns 1, indicating SIRC is valid
5. Read SIRCCSR[SIRCERR] to ensure it returns 0
6. Write 2 to RCCR[SCS] to switch main clock to SIRC
7. Read CSR[SCS] until it returns 2, indicating the switch is complete
8. Write 1 to SIRCCSR[LK] to lock SIRCCSR

### 22.6.2.2 SIRC auto trim example

1. Follow steps 1 through 8 in [SOSC configuration example](#)
2. Write 2 to SIRCTCFG[TRIMSRC] to select SOSC as auto trim clock source
3. Write 39 to SIRCTCFG[TRIMDIV] to divide SOSC to 1 MHz
4. Write 0 to SIRCCSR[LK] to unlock SIRCCSR
5. Write 1 to SIRCCSR[SIRCTREN] to enable auto trim
6. Write 1 to SIRCCSR[SIRCTRUP] to enable update
7. Read SIRCCSR[SIRCVLD] until it returns 1, indicating SIRC is valid
8. Read SIRCCSR[SIRCERR] to ensure it returns 0
9. Read SIRCCSR[JTRIM\_LOCK] until it returns 1.
10. Write 1 to SIRCCSR[LK] to lock SIRCCSR

The auto trim process continues until it is disabled. The SIRCSTAT register shows the locked trim values. If there is an unlock after lock, SIRCCSR[SIRCERR] is set.

### 22.6.3 FIRC configuration example

#### 22.6.3.1 FIRC normal configuration example

1. Write 111 to FIRCCFG[FREQ\_SEL] to select 192 MHz
2. Write 0 to FIRCCSR[LK] to unlock FIRCCSR
3. Write 0 to FIRCCSR[FIRC\_FCLK\_PERIPH\_EN] to disable FIRC\_HF clock for peripheral use, by default FIRC\_HF is enabled
4. Write 1 to FIRCCSR[FIRC\_SCLK\_PERIPH\_EN] to enable FIRC 48 MHz clock for peripheral use if needed
5. Write 1 to FIRCCSR[FIRCSTEN] to enable FIRC clock source in Deep Sleep mode if needed
6. Read FIRCCSR[FIRCVLD] until it returns 1, indicating FIRC is valid
7. Read FIRCCSR[FIRCERR] to ensure it returns 0
8. Write 3 to RCCR[SCS] to switch main clock to FIRC
9. Read CSR[SCS] until it returns 3, indicating the switch is complete
10. Write 0 to FIRCCSR[FIRCEN] to disable FIRC, by default FIRC is enabled
11. Write 1 to FIRCCSR[LK] to lock FIRCCSR

#### 22.6.3.2 FIRC auto trim example

1. sosc\_clk\_enable(); // Enable SOSC clock
2. wait\_sosc\_valid(); // Wait SOSC to be valid
3. Write 2 to FIRCTCFG[TRIMSRC] to select SOSC as auto trim clock source
4. Write 39 to FIRCTCFG[TRIMDIV] to divide SOSC to 1 MHz
5. Write 0 to FIRCCSR[LK] to unlock FIRCCSR
6. Write 1 to FIRCCSR[FIRCTREN] to enable auto trim
7. Write 1 to FIRCCSR[FIRCTRUP] to enable update
8. Read FIRCCSR[FIRCVLD] until it returns 1, indicating FIRC is valid
9. Read FIRCCSR[FIRCERR] to ensure it returns 0

10. Read FIRCCSR[TRIM\_LOCK] until it returns 1
11. Write 1 to FIRCCSR[LK] to lock FIRCCSR

The auto trim process continues until it is disabled. The FIRCSTAT register shows the locked trim values. If there is an unlock after lock, FIRCCSR[FIRCERR] is set.

#### 22.6.4 ROSC configuration example

1. Write 0 to ROSCCSR[LK] to unlock ROSCCSR
2. Read ROSCCSR[ROSCVLD] until it returns 1, indicating ROSC is valid
3. Read ROSCCSR[ROSCERR] to ensure it returns 0
4. Write 4 to RCCR[SCS] to switch main clock to ROSC
5. Read CSR[SCS] until it returns 4, indicating the switch is complete
6. Write 1 to ROSCCSR[LK] to lock ROSCCSR

### 22.7 Memory map and register definition

This section includes information about the memory map and register definitions:

- Accesses on non-implemented registers that are outside the SCG maximum illegal address range generate a transfer error.
- Read accesses on non-implemented registers that are inside the SCG maximum illegal address range do not generate a transfer error.
- Write accesses on non-implemented registers that are inside the SCG maximum illegal address range generate a transfer error.
- Write accesses on read-only registers generate a transfer error.
- Only 32-bit writes are allowed for any writable SCG registers. Writes of 8 or 16 bits result in transfer errors.

#### 22.7.1 SCG register descriptions

##### 22.7.1.1 SCG memory map

SCG0 base address: 4008\_F000h

| Offset | Register                                    | Width<br>(In bits) | Access | Reset value |
|--------|---------------------------------------------|--------------------|--------|-------------|
| 0h     | Version ID Register (VERID)                 | 32                 | R      | 0000_0000h  |
| 4h     | Parameter Register (PARAM)                  | 32                 | R      | 0000_001Eh  |
| 8h     | Trim Lock register (TRIM_LOCK)              | 32                 | RW     | 0000_0000h  |
| 10h    | Clock Status Register (CSR)                 | 32                 | R      | 0300_0000h  |
| 14h    | Run Clock Control Register (RCCR)           | 32                 | RW     | 0300_0000h  |
| 100h   | SOSC Control Status Register (SOSCCSR)      | 32                 | RW     | 0000_0000h  |
| 108h   | SOSC Configuration Register (SOSCCFG)       | 32                 | RW     | 0000_0000h  |
| 200h   | SIRC Control Status Register (SIRCCSR)      | 32                 | RW     | 0100_0020h  |
| 20Ch   | SIRC Trim Configuration Register (SIRCTCFG) | 32                 | RW     | 0000_0000h  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset | Register                                      | Width<br>(In bits) | Access | Reset value                 |
|--------|-----------------------------------------------|--------------------|--------|-----------------------------|
| 210h   | SIRC Trim Register (SIRCTRIM)                 | 32                 | RW     | <a href="#">See section</a> |
| 218h   | SIRC Auto-trimming Status Register (SIRCSTAT) | 32                 | RW     | <a href="#">See section</a> |
| 300h   | FIRC Control Status Register (FIRCCSR)        | 32                 | RW     | <a href="#">See section</a> |
| 308h   | FIRC Configuration Register (FIRCCFG)         | 32                 | RW     | 0000_0003h                  |
| 30Ch   | FIRC Trim Configuration Register (FIRCTCFG)   | 32                 | RW     | 0000_0000h                  |
| 310h   | FIRC Trim Register (FIRCTRIM)                 | 32                 | RW     | <a href="#">See section</a> |
| 318h   | FIRC Auto-trimming Status Register (FIRCSTAT) | 32                 | RW     | <a href="#">See section</a> |
| 400h   | ROSC Control Status Register (ROSCCSR)        | 32                 | RW     | 0000_0000h                  |

### 22.7.1.2 Version ID Register (VERID)

#### Offset

| Register | Offset |
|----------|--------|
| VERID    | 0h     |

#### Function

The Version ID register indicates the version integrated for this instance on the device.

#### NOTE

Writing to this register results in a transfer error.

#### Diagram



**Fields**

| Field   | Function                                                    |
|---------|-------------------------------------------------------------|
| 31-0    | SCG Version Number                                          |
| VERSION | This read-only field returns the SCG module version number. |

**22.7.1.3 Parameter Register (PARAM)****Offset**

| Register | Offset |
|----------|--------|
| PARAM    | 4h     |

**Function**

The Parameter register indicates the feature parameters for this instance on the device.

**NOTE**

Writing to this register results in a transfer error.

**Diagram**

|       |    |    |    |    |    |    |    |    |    |    |    |    |                |                |                |                |   |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----------------|----------------|----------------|----------------|---|
| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19             | 18             | 17             | 16             |   |
|       | R  |    |    |    |    |    |    |    | 0  |    |    |    |                |                |                |                |   |
|       | W  |    |    |    |    |    |    |    |    |    |    |    |                |                |                |                |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0              | 0              | 0              | 0              |   |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3              | 2              | 1              | 0              |   |
|       | R  |    |    |    | 0  |    |    |    | 1  | 0  | 0  | 0  | ROSC<br>CLK... | FIRCC<br>LK... | SIRCC<br>LK... | SOSC<br>CLK... | 0 |
|       | W  |    |    |    |    |    |    |    |    |    |    |    |                |                |                |                |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1              | 1              | 1              | 0              |   |

**Fields**

| Field | Function |
|-------|----------|
| 31-9  | Reserved |
| —     |          |
| 8     | Reserved |
| —     |          |
| 7     | Reserved |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                               |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------|
| —            |                                                                                                                                        |
| 6            | Reserved                                                                                                                               |
| —            |                                                                                                                                        |
| 5            | Reserved                                                                                                                               |
| —            |                                                                                                                                        |
| 4            | ROSC Clock Present                                                                                                                     |
| ROSCCLKPRES  | Indicates that the ROSC(FRO16K) clock source is present.<br>0b - ROSC clock source is not present<br>1b - ROSC clock source is present |
| 3            | FIRC Clock Present                                                                                                                     |
| FIRCCCLKPRES | Indicates that the FIRC clock source is present.<br>0b - FIRC clock source is not present<br>1b - FIRC clock source is present         |
| 2            | SIRC Clock Present                                                                                                                     |
| SIRCCLKPRES  | Indicates that the SIRC clock source is present.<br>0b - SIRC clock source is not present<br>1b - SIRC clock source is present         |
| 1            | SOSC Clock Present                                                                                                                     |
| SOSCCLKPRES  | Indicates that the SOSC clock source is present.<br>0b - SOSC clock source is not present<br>1b - SOSC clock source is present         |
| 0            | Reserved                                                                                                                               |
| —            |                                                                                                                                        |

#### 22.7.1.4 Trim Lock register (TRIM\_LOCK)

##### Offset

| Register  | Offset |
|-----------|--------|
| TRIM_LOCK | 8h     |

##### Function

The Trim Lock Register contains the TRIM\_UNLOCK and IFR\_DISABLE bits.

**NOTE**

The bits reset solely on a POR/LVD event.

**Diagram**

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19 | 18 | 17             | 16             |
|-------|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----------------|----------------|
| R     |    |    |    |    |    |    |    |    | 0             |    |    |    |    |    |                |                |
| W     |    |    |    |    |    |    |    |    | TRIM_LOCK_KEY |    |    |    |    |    |                |                |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0              | 0              |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7             | 6  | 5  | 4  | 3  | 2  | 1              | 0              |
| R     |    |    |    |    |    |    |    |    | 0             |    |    |    |    |    |                |                |
| W     |    |    |    |    |    |    |    |    |               |    |    |    |    |    | IFR_DI<br>S... | TRIM_<br>UN... |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0  | 0              | 0              |

**Fields**

| Field                      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>TRIM_LOCK_K<br>EY | <p><b>TRIM_LOCK_KEY</b></p> <p>Write value that is used to unlock writes to the IFR_DISABLE and TRIM_UNLOCK registers.</p> <p><b>NOTE</b><br/>A write value of 0x5a5a allows writes to the IFR_DISABLE and TRIM_UNLOCK to take affect.</p> <p><b>NOTE</b><br/>Writable but reads always return a 0 value.</p>                                                                                                                                                                                                                                                |
| 15-2<br>—                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1<br>IFR_DISABLE           | <p><b>IFR_DISABLE</b></p> <p>Locks IFR write access to SCG trim registers. When set, prevents SCG trim registers from getting IFR loaded during warm reset.</p> <p><b>NOTE</b><br/>IFR_DISABLE is writable during write access to TRIM_LOCK and only when the TRIM_LOCK[31:16] write value is equal to 16'h5a5a.</p> <p>0b - IFR write access to SCG trim registers not disabled. The SCG Trim registers are reprogrammed with the IFR values after any system reset.</p> <p>1b - IFR write access to SCG trim registers during system reset is blocked.</p> |
| 0<br>TRIM_UNLOCK           | Locks user writes access to SCG Trim Configuration registers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                       |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <p style="text-align: center;"><b>NOTE</b></p> <p>TRIM_UNLOCK is writable during write access to TRIM_LOCK and only when the TRIM_LOCK[31:16] write value is equal to 16'h5a5a.</p> <p>0b - SCG Trim Registers locked and not writable.<br/>1b - SCG Trim registers unlocked and writable.</p> |

### 22.7.1.5 Clock Status Register (CSR)

#### Offset

| Register | Offset |
|----------|--------|
| CSR      | 10h    |

#### Function

The Clock Status Register shows the currently configured clock source that is generating the system clock.

**NOTE**

Writing to the Clock Status Register (CSR) results in a transfer error.

#### Diagram

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

#### Fields

| Field | Function            |
|-------|---------------------|
| 31-27 | Reserved            |
| 26-24 | System Clock Source |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                                                         |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SCS       | Returns the currently configured clock source generating the system clock. Reports the configuration set by the RCCR.<br><br>000b - Reserved<br>001b - SOSC<br>010b - SIRC<br>011b - FIRC<br>100b - ROSC<br>101b-111b - Reserved |
| 23-0<br>— | Reserved                                                                                                                                                                                                                         |

### 22.7.1.6 Run Clock Control Register (RCCR)

#### Offset

| Register | Offset |
|----------|--------|
| RCCR     | 14h    |

#### Function

The Run Clock Control Register selects the clock source generating the system clock.

---

#### NOTE

Switching to new system clock source must be done after previous RCCR changes have been completed and the Clock Status Register has been updated to match the present RCCR setting.

#### Diagram



**Fields**

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-27<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 26-24<br>SCS | <p>System Clock Source</p> <p>Selects the clock source generating the system clock in Run mode. Attempting to select a clock that is not valid is ignored. Selecting a different clock source when in Run mode requires that clock source to be enabled first and be valid before system clocks are allowed to switch to that clock source.</p> <p><b>NOTE</b></p> <p>Programming SCS to a different value must only be done after the previous SCS clock switch has completed.</p> <p>000b - Reserved<br/>001b - SOSC<br/>010b - SIRC<br/>011b - FIRC<br/>100b - ROSC<br/>101b-111b - Reserved</p> |
| 23-0<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

**22.7.1.7 SOSC Control Status Register (SOSCCSR)****Offset**

| Register | Offset |
|----------|--------|
| SOSCCSR  | 100h   |

**Function**

The SOSC Control Status Register contains control and status bits for the SOSC clock source.

**Diagram**

| Bits  | 31 | 30             | 29 | 28 | 27          | 26          | 25          | 24 | 23 | 22 | 21 | 20 | 19           | 18           | 17         | 16 |
|-------|----|----------------|----|----|-------------|-------------|-------------|----|----|----|----|----|--------------|--------------|------------|----|
| R     | 0  | SOSC<br>VLD... |    | 0  | SOSC<br>ERR | SOSC<br>SEL | SOSC<br>VLD |    | LK |    | 0  |    | SOSC<br>CMRE | SOSC<br>CM   |            |    |
| W     |    |                |    |    | W1C         |             |             |    |    |    |    |    |              |              |            |    |
| Reset | 0  | 0              | 0  | 0  | 0           | 0           | 0           | 0  | 0  | 0  | 0  | 0  | 0            | 0            | 0          | 0  |
| Bits  | 15 | 14             | 13 | 12 | 11          | 10          | 9           | 8  | 7  | 6  | 5  | 4  | 3            | 2            | 1          | 0  |
| R     |    |                |    |    |             |             |             | 0  |    |    |    |    | 0            | SOSC<br>STEN | SOSC<br>EN |    |
| W     |    |                |    |    |             |             |             |    |    |    |    |    |              |              |            |    |
| Reset | 0  | 0              | 0  | 0  | 0           | 0           | 0           | 0  | 0  | 0  | 0  | 0  | 0            | 0            | 0          | 0  |

**Fields**

| Field            | Function                                                                                                                                                                                                                                                   |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31               | Reserved                                                                                                                                                                                                                                                   |
| —                |                                                                                                                                                                                                                                                            |
| 30<br>SOSCVLD_IE | SOSC Valid Interrupt Enable<br><br>Generates an interrupt when SOSCVLD is asserted.<br><br>0b - SOSCVLD interrupt is not enabled<br>1b - SOSCVLD interrupt is enabled                                                                                      |
| 29-27            | Reserved                                                                                                                                                                                                                                                   |
| —                |                                                                                                                                                                                                                                                            |
| 26<br>SOSCERR    | SOSC Clock Error<br><br>This flag is reset on Chip POR only, software can also clear this flag by writing a logic one.<br><br>0b - SOSC Clock Monitor is disabled or has not detected an error<br>1b - SOSC Clock Monitor is enabled and detected an error |
| 25<br>SOSCSEL    | SOSC Selected<br><br>This flag shows the SOSC clock source is selected as the system clock source.<br><br>0b - SOSC is not the system clock source<br>1b - SOSC is the system clock source                                                                 |
| 24<br>SOSCVLD    | SOSC Valid<br><br>This flag shows the SOSC clock source is valid.<br><br>0b - SOSC is not enabled or clock is not valid<br>1b - SOSC is enabled and output clock is valid                                                                                  |
| 23               | Lock Register                                                                                                                                                                                                                                              |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LK             | <p>Locks this register so that it cannot be written to.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field can be cleared/set at any time.</p> <p style="margin-left: 40px;">0b - This Control Status Register can be written<br/>1b - This Control Status Register cannot be written</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 22-18<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 17<br>SOSCCMRE | <p>SOSC Clock Monitor Reset Enable</p> <p>Enables the SOSCERR generate reset.</p> <p style="margin-left: 40px;">0b - Clock monitor generates an interrupt when an error is detected<br/>1b - Clock monitor generates a reset when an error is detected</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 16<br>SOSCCM   | <p>SOSC Clock Monitor Enable</p> <p>Enables the clock monitor when SOSCVLD is set.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>SOSC clock monitor remains enabled in Deep Sleep mode only if SOSCCM and SOSCSTEN are enabled. If the clock is disabled in Deep Sleep mode, then SOSCCM must be cleared to prevent unexpected SOSC loss of clock. The clock monitor is always disabled in Power Down and Deep Power Down modes. When the clock monitor is disabled in a low power mode, it remains disabled until the clock valid flag is set, following exit from the low power mode.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>The reference clock used to monitor the SOSC is the SIRC. This clock must be programmed to be enabled in order to monitor the SOSC. SIRC is automatically disabled in Power Down and Deep Power Down modes and the clock monitor of SOSC is disabled.</p> <p style="margin-left: 40px;">0b - SOSC Clock Monitor is disabled<br/>1b - SOSC Clock Monitor is enabled</p> |
| 15-3<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1<br>SOSCSTEN  | <p>SOSC Stop Enable</p> <p>Enables the SOSC clock source in Deep Sleep mode if SOSCEN is set.</p> <p style="margin-left: 40px;">0b - SOSC is disabled in Deep Sleep mode</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                       |
|-------------|------------------------------------------------------------------------------------------------|
|             | 1b - SOSC is enabled in Deep Sleep mode only if SOSCEN is set                                  |
| 0<br>SOSCEN | SOSC Enable<br>Enables the SOSC clock source.<br>0b - SOSC is disabled<br>1b - SOSC is enabled |

### 22.7.1.8 SOSC Configuration Register (SOSCCFG)

#### Offset

| Register | Offset |
|----------|--------|
| SOSCCFG  | 108h   |

#### Function

The SOSC Configuration Register contains the clock frequency range select and external reference select for the SOSC clock source.

#### NOTE

The SOSCCFG register cannot be changed when the SOSC is enabled. When the SOSC is enabled, writes to this register are ignored, and there is no transfer error.

#### Diagram

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

#### Fields

| Field | Function |
|-------|----------|
| 31-12 | Reserved |
| —     |          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11-8<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                  |
| 7-6<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                  |
| 5-4<br>RANGE | <p>SOSC Range Select</p> <p>Selects the frequency range for the system crystal oscillator (OSC).</p> <ul style="list-style-type: none"> <li>00b - Frequency range select of 8-16 MHz.</li> <li>01b - Frequency range select of 16-25 MHz.</li> <li>10b - Frequency range select of 25-40 MHz.</li> <li>11b - Frequency range select of 40-50 MHz.</li> </ul>                              |
| 3<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                  |
| 2<br>EREFs   | <p>External Reference Select</p> <p>Selects the source for the external reference clock. This bit selects which clock is output from the SOSC into the SCG, whether from the crystal oscillator or from an external clock input.</p> <ul style="list-style-type: none"> <li>0b - External reference clock selected.</li> <li>1b - Internal crystal oscillator of OSC selected.</li> </ul> |
| 1-0<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                  |

#### 22.7.1.9 SIRC Control Status Register (SIRCCSR)

##### Offset

| Register | Offset |
|----------|--------|
| SIRCCSR  | 200h   |

##### Function

The SIRC Control Status Register contains control and status bits for the SIRC clock source.

**Diagram**

| Bits  | 31 | 30 | 29 | 28 | 27             | 26             | 25           | 24           | 23 | 22             | 21 | 20 | 19           | 18 | 17 | 16 |
|-------|----|----|----|----|----------------|----------------|--------------|--------------|----|----------------|----|----|--------------|----|----|----|
| R     | 0  |    |    |    | SIRCE<br>RR    | SIRCS<br>EL    | SIRC<br>LD   |              | LK | 0              |    |    |              |    |    |    |
| W     |    |    |    |    | W1C            |                |              |              |    |                |    |    |              |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0              | 0              | 0            | 1            | 0  | 0              | 0  | 0  | 0            | 0  | 0  | 0  |
| Bits  | 15 | 14 | 13 | 12 | 11             | 10             | 9            | 8            | 7  | 6              | 5  | 4  | 3            | 2  | 1  | 0  |
| R     | 0  |    |    |    | COAR<br>SE.... | TRIM_<br>LO... | SIRCT<br>RUP | SIRCT<br>REN | 0  | SIRC_<br>CL... | 0  |    | SIRCS<br>TEN | 0  |    |    |
| W     |    |    |    |    |                |                |              |              |    |                |    |    | 0            | 0  | 0  | 0  |
| Reset | 0  | 0  | 0  | 0  | 0              | 0              | 0            | 0            | 0  | 0              | 1  | 0  | 0            | 0  | 0  | 0  |

**Fields**

| Field            | Function                                                                                                                                                                                                          |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-28            | Reserved                                                                                                                                                                                                          |
| —                |                                                                                                                                                                                                                   |
| 27<br>SIRCERR_IE | SIRC Clock Error Interrupt Enable<br>Generates an interrupt when SIRCERR is asserted.<br>0b - SIRCERR interrupt is not enabled<br>1b - SIRCERR interrupt is enabled                                               |
| 26<br>SIRCERR    | SIRC Clock Error<br>This flag is reset on Chip POR only, software can also clear this flag by writing a logic one<br>0b - Error not detected with the SIRC trimming<br>1b - Error detected with the SIRC trimming |
| 25<br>SIRCSEL    | SIRC Selected<br>This flag shows the SIRC clock source is selected as the system clock source.<br>0b - SIRC is not the system clock source<br>1b - SIRC is the system clock source                                |
| 24<br>SIRCVLD    | SIRC Valid<br>This flag shows the SIRC clock source is valid.<br>0b - SIRC is not enabled or clock is not valid<br>1b - SIRC is enabled and output clock is valid                                                 |
| 23<br>LK         | Lock Register<br>This field can be cleared/set at any time. The purpose for this bitfield is to prevent runaway code from changing SIRC clock configurations.                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                              | 0b - Control Status Register can be written<br>1b - Control Status Register cannot be written                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 22-12<br>—                   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 11<br>COARSE_TRIM<br>_BYPASS | Coarse Auto Trim Bypass<br>This bit is to bypass the coarse trim step when auto-trimming.<br>0b - SIRC Coarse Auto Trim NOT Bypassed<br>1b - SIRC Coarse Auto Trim Bypassed                                                                                                                                                                                                                                                                                                                                                                                                               |
| 10<br>TRIM_LOCK              | SIRC TRIM LOCK<br>When SIRCTREN and SIRCTRUP are enabled, TRIM_LOCK indicates when auto trimming is complete and output SIRC frequency has locked to target SIRC range.<br><div style="text-align: center;"> <b>NOTE</b> <ul style="list-style-type: none"> <li>This field is automatically cleared if SIRCTREN and SIRCTRUP are not set.</li> <li>TRIM_LOCK is not set when SIRCTCFG[TRIMSRC] = 2'b00, i.e., using full speed USB as the trim source.</li> </ul> </div> 0b - SIRC auto trim not locked to target frequency range<br>1b - SIRC auto trim locked to target frequency range |
| 9<br>SIRCTRUP                | SIRC Trim Update<br>This bit allows the SIRCSTAT to be updated by the auto-trimming hardware.<br>0b - Disables SIRC trimming updates<br>1b - Enables SIRC trimming updates                                                                                                                                                                                                                                                                                                                                                                                                                |
| 8<br>SIRCTREN                | SIRC 12 MHz Trim Enable (SIRCCFG[RANGE]=1)<br>This bit enables the auto trim of SIRC 12 MHz by an external clock source.<br>0b - Disables trimming SIRC to an external clock source<br>1b - Enables trimming SIRC to an external clock source                                                                                                                                                                                                                                                                                                                                             |
| 7-6<br>—                     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5<br>SIRC_CLK_PE<br>RIPH_EN  | SIRC Clock to Peripherals Enable<br>This bit enables the SIRC clock for peripheral use.<br>0b - SIRC clock to peripherals is disabled<br>1b - SIRC clock to peripherals is enabled                                                                                                                                                                                                                                                                                                                                                                                                        |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                     |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4-2<br>—      | Reserved                                                                                                                                                     |
| 1<br>SIRCSTEN | SIRC Stop Enable<br>Enables the SIRC clock source in Deep Sleep mode.<br>0b - SIRC is disabled in Deep Sleep mode<br>1b - SIRC is enabled in Deep Sleep mode |
| 0<br>—        | Reserved                                                                                                                                                     |

#### 22.7.1.10 SIRC Trim Configuration Register (SIRCTCFG)

##### Offset

| Register | Offset |
|----------|--------|
| SIRCTCFG | 20Ch   |

##### Function

The SIRC Trim Configuration Register contains the auto trim clock source select and trim clock divider control for the SIRC clock source.

##### NOTE

The SIRCTCFG register cannot be changed when SIRC tuning is enabled. When the SIRC tuning is enabled, writes to this register are ignored, and there is no transfer error.

##### Diagram



**Fields**

| Field            | Function                                                                                                                                                                                                                                                                                                                          |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-23<br>—       | Reserved                                                                                                                                                                                                                                                                                                                          |
| 22-16<br>TRIMDIV | SIRC Trim Pre-divider<br><br>Divider of SOSC for SIRC trimming.<br><br><b>NOTE</b><br>When selecting SOSC as SIRC trimming source the TRIMDIV register must be set to correct div ratio to generate 1 MHz output reference trimming clock.                                                                                        |
| 15-11<br>—       | Reserved                                                                                                                                                                                                                                                                                                                          |
| 10-8<br>—        | Reserved                                                                                                                                                                                                                                                                                                                          |
| 7-2<br>—         | Reserved                                                                                                                                                                                                                                                                                                                          |
| 1-0<br>TRIMSRC   | Trim Source<br><br>Configures the external clock source to tune the SIRC. TRIMSRC must be configured before programming SIRCSTAT register for trim update<br><br>00b - Reserved<br>01b - Reserved<br>10b - SOSC. This option requires that SOSC be divided using the TRIMDIV field to get a frequency of 1 MHz.<br>11b - Reserved |

**22.7.1.11 SIRC Trim Register (SIRCTRIM)****Offset**

| Register | Offset |
|----------|--------|
| SIRCTRIM | 210h   |

**Function**

The SIRC Trim Register holds the trim values for the SIRC clock source. This register is loaded from IFR during reset.

**NOTE**

This register writes are protected by TRIM LOCK register.

**Diagram**

| Bits  | 31 | 30 | 29             | 28             | 27       | 26 | 25 | 24 | 23 | 22 | 21             | 20             | 19      | 18 | 17 | 16 |
|-------|----|----|----------------|----------------|----------|----|----|----|----|----|----------------|----------------|---------|----|----|----|
| R     | 0  |    |                |                | FVCHTRIM |    |    |    | 0  |    |                |                | TCTRIM  |    |    |    |
| W     |    |    |                |                |          |    |    |    |    |    |                |                |         |    |    |    |
| Reset | 0  | 0  | 0              | u <sup>1</sup> | u        | u  | u  | u  | 0  | 0  | 0              | u <sup>1</sup> | u       | u  | u  | u  |
| Bits  | 15 | 14 | 13             | 12             | 11       | 10 | 9  | 8  | 7  | 6  | 5              | 4              | 3       | 2  | 1  | 0  |
| R     | 0  |    |                |                | CLTRIM   |    |    |    | 0  |    |                |                | CCOTRIM |    |    |    |
| W     |    |    |                |                |          |    |    |    |    |    |                |                |         |    |    |    |
| Reset | 0  | 0  | u <sup>1</sup> | u              | u        | u  | u  | u  | 0  | 0  | u <sup>1</sup> | u              | u       | u  | u  | u  |

1. Reset values are loaded out of IFR.

**Fields**

| Field             | Function                                                                                                                                 |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| 31-29<br>—        | Reserved                                                                                                                                 |
| 28-24<br>FVCHTRIM | Calibrates the replica voltage in FSU for CCO to get well frequency at initial period                                                    |
| 23-21<br>—        | Reserved                                                                                                                                 |
| 20-16<br>TCTRIM   | Trim Temp<br>Trim bus to calibrate the relationship between freq and temperature.                                                        |
| 15-14<br>—        | Reserved                                                                                                                                 |
| 13-8<br>CLTRIM    | CL Trim<br>Trims bus to calibrate the freq of CCO in close loop mode to within approximately $\pm 0.6\%$ of the target 12 MHz frequency. |
| 7-6<br>—          | Reserved                                                                                                                                 |
| 5-0<br>CCOTRIM    | CCO Trim<br>Trims bus to calibrate the freq of CCO in open loop mode to within approximately $\pm 2.5\%$ of the target 12 MHz frequency. |

### 22.7.1.12 SIRC Auto-trimming Status Register (SIRCSTAT)

#### Offset

| Register | Offset |
|----------|--------|
| SIRCSTAT | 218h   |

#### Function

This register is loaded from IFR during warm reset.

When SIRCTREN=1 and SIRCTRUP=1, this register is uploaded with the trim values generated by SIRC auto-trimming which is enabled.

When SIRCTREN=1 and SIRCTRUP=0, writing to this register is not allowed and values read from this register are used to trim SIRC clock.

#### NOTE

TRIMSRC needs to be programmed to TRIMSRC=10, writes to this register are allowed and values written to this register are used to trim the SIRC clock.

#### Diagram



1. Reset values are loaded out of IFR.

#### Fields

| Field          | Function                                                                                                                                                                   |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-14<br>—     | Reserved                                                                                                                                                                   |
| 13-8<br>CLTRIM | CL Trim<br>CLTRIM bits are to calibrate the freq of CCO in close loop mode, are used to trim the SIRC Clock to within approximately ±0.6 % of the target 12 MHz frequency. |
| 7-6<br>—       | Reserved                                                                                                                                                                   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                  |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5-0<br>CCOTRIM | CCO Trim<br>CCOTRIM bits are to calibrate the freq of CCO in open loop mode, are used to coarsely trim the SIRC Clock to within approximately $\pm 2.5\%$ of the target 12 MHz frequency. |

### 22.7.1.13 FIRC Control Status Register (FIRCCSR)

#### Offset

| Register | Offset |
|----------|--------|
| FIRCCSR  | 300h   |

#### Function

The FIRC Control Status Register contains control and status bits for the FIRC clock source.

#### Diagram

| Bits  | 31          | 30             | 29 | 28 | 27             | 26             | 25          | 24    | 23 | 22 | 21             | 20             | 19 | 18 | 17           | 16         |
|-------|-------------|----------------|----|----|----------------|----------------|-------------|-------|----|----|----------------|----------------|----|----|--------------|------------|
| R     | FIRCA<br>CC | FIRCA<br>CC... | 0  |    | FIRCE<br>RR    | FIRCS<br>EL    | FIRCV<br>LD |       | LK | 0  |                |                | 0  |    |              |            |
| W     |             |                |    |    | FIRCE<br>RR... |                |             |       |    |    |                |                |    |    |              |            |
| Reset | u           | 0              | 0  | 0  | 0              | 0              | 1           | 1     | 0  | 0  | 0              | 0              | 0  | 0  | 0            | 0          |
| Bits  | 15          | 14             | 13 | 12 | 11             | 10             | 9           | 8     | 7  | 6  | 5              | 4              | 3  | 2  | 1            | 0          |
| R     |             |                | 0  |    | COAR           | TRIM_<br>LO... | FIRCT       | FIRCT | 0  |    | FIRC_<br>FC... | FIRC_<br>SC... | 0  |    | FIRCS<br>TEN | FIRCE<br>N |
| W     |             |                |    |    | SE...          |                | RUP         | REN   |    |    |                |                |    |    |              |            |
| Reset | 0           | 0              | 0  | 0  | 0              | 0              | 0           | 0     | 0  | 0  | 1              | 1              | 0  | 0  | 0            | 1          |

#### Fields

| Field            | Function                                                                                                                                                                                                                                                         |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>FIRCACC    | FIRC Frequency Accurate<br>This flag shows the FIRC clock source is accurate.<br>0b - FIRC is not enabled or clock is not accurate.<br>1b - FIRC is enabled and output clock is accurate after some preparation time which is obtained by counting FRO_HF clock. |
| 30<br>FIRCACC_IE | FIRC Accurate Interrupt Enable<br>Generate an interrupt when FIRCACC is asserted.                                                                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                                                           |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | 0b - FIRCACC interrupt is not enabled<br>1b - FIRCACC interrupt is enabled                                                                                                                                                                                         |
| 29-28<br>—       | Reserved                                                                                                                                                                                                                                                           |
| 27<br>FIRCERR_IE | FIRC Clock Error Interrupt Enable<br>Generate an interrupt when FIRCERR is asserted.<br>0b - FIRCERR interrupt is not enabled<br>1b - FIRCERR interrupt is enabled                                                                                                 |
| 26<br>FIRCERR    | FIRC Clock Error<br>This flag is reset on Chip POR only, software can also clear this flag by writing a logic one<br>0b - Error not detected with the FIRC trimming<br>1b - Error detected with the FIRC trimming                                                  |
| 25<br>FIRCSEL    | FIRC Selected<br>This flag shows the FIRC clock source is selected as the system clock source.<br>0b - FIRC is not the system clock source<br>1b - FIRC is the system clock source                                                                                 |
| 24<br>FIRCVLD    | FIRC Valid status<br>This flag shows the FIRC clock source is valid.<br>0b - FIRC is not enabled or clock is not valid.<br>1b - FIRC is enabled and output clock is valid. The clock is valid after there is an output clock from the FIRC analog.                 |
| 23<br>LK         | Lock Register<br>This bit field can be cleared/set at any time. The purpose for this bitfield is to prevent runaway code from changing FIRC clock configurations.<br>0b - Control Status Register can be written<br>1b - Control Status Register cannot be written |
| 22-20<br>—       | Reserved                                                                                                                                                                                                                                                           |
| 19-16<br>—       | Reserved                                                                                                                                                                                                                                                           |
| 15-12            | Reserved                                                                                                                                                                                                                                                           |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 11<br>COARSE_TRIM<br>_BYPASS | <p>Coarse Auto Trim Bypass</p> <p>This bit is to bypass the coarse trim step when auto-trimming.</p> <p>0b - FIRC Coarse Auto Trim NOT Bypassed<br/>1b - FIRC Coarse Auto Trim Bypassed</p>                                                                                                                                                                                                                                                                                                                                                                                 |
| 10<br>TRIM_LOCK              | <p>FIRC TRIM LOCK</p> <p>When FIRCTREN and FIRCTRUP are enabled, TRIM_LOCK indicates when auto trimming is complete and output FIRC frequency has locked to target FIRC range.</p> <p><b>NOTE</b></p> <ul style="list-style-type: none"> <li>• This field is automatically cleared if SIRCTREN and SIRCTRUP are not set.</li> <li>• TRIM_LOCK is not set when SIRCTCFG[TRIMSRC] = 2'b00, i.e., using full speed USB as the trim source.</li> </ul> <p>0b - FIRC auto trim not locked to target frequency range<br/>1b - FIRC auto trim locked to target frequency range</p> |
| 9<br>FIRCTRUP                | <p>FIRC Trim Update</p> <p>This bit allows the FIRCSTAT to be updated by the auto-trimming hardware.</p> <p>0b - Disables FIRC trimming updates<br/>1b - Enables FIRC trimming updates</p>                                                                                                                                                                                                                                                                                                                                                                                  |
| 8<br>FIRCTREN                | <p>FRO_HF Trim Enable</p> <p>This bit enables the auto trim of FRO_HF by an external clock source.</p> <p>0b - Disables trimming FRO_HF by an external clock source<br/>1b - Enables trimming FRO_HF by an external clock source</p>                                                                                                                                                                                                                                                                                                                                        |
| 7-6<br>—                     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 5<br>FIRC_FCLK_PE<br>RIPH_EN | <p>FRO_HF Clock to peripherals Enable</p> <p>This bit enables the FRO_HF clock for peripheral use.</p> <p>0b - FRO_HF to peripherals is disabled<br/>1b - FRO_HF to peripherals is enabled</p>                                                                                                                                                                                                                                                                                                                                                                              |
| 4<br>FIRC_SCLK_P<br>ERIPH_EN | <p>FIRC 48 MHz Clock to peripherals Enable</p> <p>This bit enables the FIRC 48 MHz clock for peripheral use.</p> <p>0b - FIRC 48 MHz to peripherals is disabled<br/>1b - FIRC 48 MHz to peripherals is enabled</p>                                                                                                                                                                                                                                                                                                                                                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                      |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3-2<br>—      | Reserved                                                                                                                                                                      |
| 1<br>FIRCSTEN | FIRC Stop Enable<br>Enables the FIRC clock source in Deep Sleep mode if FIRCEN is set.<br>0b - FIRC is disabled in Deep Sleep mode<br>1b - FIRC is enabled in Deep Sleep mode |
| 0<br>FIRCEN   | FIRC Enable<br>Enables the FIRC clock source.<br>0b - FIRC is disabled<br>1b - FIRC is enabled                                                                                |

#### 22.7.1.14 FIRC Configuration Register (FIRCCFG)

##### Offset

| Register | Offset |
|----------|--------|
| FIRCCFG  | 308h   |

##### Function

The FIRC Configuration Register controls the clock frequency range select for the FIRC clock source.

##### Diagram

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

**Fields**

| Field           | Function                                                                                                                                                                                                                                                                                                                                                           |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                           |
| 3-1<br>FREQ_SEL | <p>Frequency select</p> <p>These bits are used to select the frequency for FRO_HF clock when used as system clock.</p> <ul style="list-style-type: none"> <li>001b - 48 MHz FIRC clock selected, divided from 192 MHz</li> <li>011b - 64 MHz FIRC clock selected</li> <li>101b - 96 MHz FIRC clock selected</li> <li>111b - 192 MHz FIRC clock selected</li> </ul> |
| 0<br>—          | Reserved                                                                                                                                                                                                                                                                                                                                                           |

**22.7.1.15 FIRC Trim Configuration Register (FIRCTCFG)****Offset**

| Register | Offset |
|----------|--------|
| FIRCTCFG | 30Ch   |

**Function**

The FIRCTCFG register contains the auto trim clock source select and trim clock divider control for the FIRC clock source.

**NOTE**

The FIRCTCFG register cannot be changed when FIRC tuning is enabled. When the FIRC tuning is enabled, writes to this register are ignored, and there is no transfer error.

**Diagram**

**Fields**

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-23<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                  |
| 22-16<br>TRIMDIV | FIRC Trim Pre-divider<br><br>Divider of SOSC for FIRC trimming.<br><br><b>NOTE</b><br>When selecting SOSC as FIRC trimming source the TRIMDIV register must be set to correct div ratio to generate 1 MHz output reference trimming clock.                                                                                                                                                |
| 15-11<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                  |
| 10-8<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                  |
| 7-2<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                  |
| 1-0<br>TRIMSRC   | Trim Source<br><br>Configures the external clock source to tune the FIRC. TRIMSRC must be configured before programming FIRCSTAT register for trim update.<br><br>00b - USB0 Start of Frame (1 KHz). This option does not use TRIMDIV .<br>01b - Reserved<br>10b - SOSC. This option requires that SOSC be divided using the TRIMDIV field to get a frequency of 1 MHz.<br>11b - Reserved |

**22.7.1.16 FIRC Trim Register (FIRCTRIM)****Offset**

| Register | Offset |
|----------|--------|
| FIRCTRIM | 310h   |

**Function**

The FIRC Trim Register holds the trim values for the FIRC clock source. This register is loaded from IFR during reset. These values are used for trimming the different selected frequencies (from 48 to 192 MHz by FIRCCFG[FREQ\_SEL]) of FIRC.

**NOTE**

This register writes are protected by TRIM LOCK register.

**Diagram**

| Bits  | 31 | 30 | 29             | 28 | 27        | 26 | 25 | 24 | 23             | 22 | 21 | 20 | 19             | 18 | 17 | 16 |
|-------|----|----|----------------|----|-----------|----|----|----|----------------|----|----|----|----------------|----|----|----|
| R     | 0  |    |                |    | TRIMSTART |    |    |    | 0              |    |    |    | TRIMTEMP2      |    | 0  |    |
| W     |    |    |                |    |           |    |    |    |                |    |    |    |                |    |    |    |
| Reset | 0  | 0  | u <sup>1</sup> | u  | u         | u  | u  | u  | 0              | 0  | 0  | 0  | u <sup>1</sup> | u  | 0  | 0  |
| Bits  | 15 | 14 | 13             | 12 | 11        | 10 | 9  | 8  | 7              | 6  | 5  | 4  | 3              | 2  | 1  | 0  |
| R     | 0  |    |                |    | TRIMCOAR  |    |    |    | TRIMFINE       |    |    |    |                |    |    |    |
| W     |    |    |                |    |           |    |    |    |                |    |    |    |                |    |    |    |
| Reset | 0  | 0  | u <sup>1</sup> | u  | u         | u  | u  | u  | u <sup>1</sup> | u  | u  | u  | u              | u  | u  | u  |

1. Reset values are loaded out of IFR.

**Fields**

| Field              | Function                                                                                                                                                           |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30<br>—         | Reserved                                                                                                                                                           |
| 29-24<br>TRIMSTART | Trim Start<br>Current dac adjustment of the replica cco current of start-up circuit.                                                                               |
| 23-20<br>—         | Reserved                                                                                                                                                           |
| 19-18<br>TRIMTEMP2 | Trim Temperature2<br>Temperature coefficient compensation for 192 MHz.                                                                                             |
| 17-16<br>—         | Reserved                                                                                                                                                           |
| 15-14<br>—         | Reserved                                                                                                                                                           |
| 13-8<br>TRIMCOAR   | Trim Coarse<br>TRIMCOAR bits are used to coarsely trim the FIRC Clock to within approximately ±3.2% of the target frequency.                                       |
| 7-0<br>TRIMFINE    | Trim Fine<br>Current DAC adjustment of the CCO current. TRIMFINE bits are used to fine trim the FIRC Clock to within approximately ±0.25% of the target frequency. |

### 22.7.1.17 FIRC Auto-trimming Status Register (FIRCSTAT)

#### Offset

| Register | Offset |
|----------|--------|
| FIRCSTAT | 318h   |

#### Function

This register is loaded from IFR during reset. This register is uploaded with the trim values generated by FIRC auto-trimming which is enabled when FIRC is enabled and FIRCTREN=1 and FIRCTRUP=1. When FIRCTREN=1 and FIRCTRUP=0 (Note: TRIMSRC needs to be programmed to TRIMSRC=10), writes to this register are allowed and values written to this register are used to trim FIRC clock.

#### Diagram

| Bits  | 31 | 30       | 29             | 28 | 27 | 26 | 25 | 24       | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----------|----------------|----|----|----|----|----------|----|----|----|----|----|----|----|----|
| R     | 0  |          |                |    |    |    |    |          |    |    |    |    |    |    |    |    |
| W     |    |          |                |    |    |    |    |          |    |    |    |    |    |    |    |    |
| Reset | 0  | 0        | 0              | 0  | 0  | 0  | 0  | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bits  | 15 | 14       | 13             | 12 | 11 | 10 | 9  | 8        | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     | 0  | TRIMCOAR |                |    |    |    |    | TRIMFINE |    |    |    |    |    |    |    |    |
| W     |    |          |                |    |    |    |    |          |    |    |    |    |    |    |    |    |
| Reset | 0  | 0        | u <sup>1</sup> | u  | u  | u  | u  | u        | u  | u  | u  | u  | u  | u  | u  | u  |

1. Reset values are loaded out of IFR.

#### Fields

| Field            | Function                                                                                                                                                                                      |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—       | Reserved                                                                                                                                                                                      |
| 15-14<br>—       | Reserved                                                                                                                                                                                      |
| 13-8<br>TRIMCOAR | Trim Coarse<br>TRIMCOAR bits are for the current DAC adjustment of the base current, are used to coarsely trim the FIRC Clock to within approximately $\pm 3.2\%$ of the target FRO_HF clock. |
| 7-0<br>TRIMFINE  | Trim Fine<br>TRIMFINE bits are for the current DAC adjustment of the CCO current, are used to trim the FIRC Clock to within approximately $\pm 0.25\%$ of the target FRO_HF clock.            |

### 22.7.1.18 ROSC Control Status Register (ROSCCSR)

#### Offset

| Register | Offset |
|----------|--------|
| ROSCCSR  | 400h   |

#### Function

The ROSC Control Status Register contains control and status bits for the ROSC(FRO16K) clock source.

#### Diagram



#### Fields

| Field         | Function                                                                                                                                                                                                |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-27<br>—    | Reserved                                                                                                                                                                                                |
| 26<br>ROSCERR | ROSC Clock Error<br>This flag is reset on Chip POR only, software can also clear this flag by writing a logic one<br>0b - ROSC Clock has not detected an error<br>1b - ROSC Clock has detected an error |
| 25<br>ROSCSEL | ROSC Selected<br>This flag shows the ROSC clock source is selected as the system clock source.<br>0b - ROSC is not the system clock source<br>1b - ROSC is the system clock source                      |
| 24<br>ROSCVLD | ROSC Valid<br>This flag shows the ROSC clock source is valid.<br>0b - ROSC is not enabled or clock is not valid                                                                                         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                               |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | 1b - ROSC is enabled and output clock is valid                                                                                                                                                                                                                                                                         |
| 23<br>LK   | <p>Lock Register</p> <p>Locks this register so that it cannot be written to.</p> <p style="text-align: center;"><b>NOTE</b></p> <p style="text-align: center;">This field can be cleared/set at any time.</p> <p>0b - Control Status Register can be written</p> <p>1b - Control Status Register cannot be written</p> |
| 22-18<br>— | Reserved                                                                                                                                                                                                                                                                                                               |
| 17-16<br>— | Reserved                                                                                                                                                                                                                                                                                                               |
| 15-0<br>—  | Reserved                                                                                                                                                                                                                                                                                                               |

# Chapter 23

## Power Management

### 23.1 Introduction

This chapter describes the power modes supported with this device. It also describes the power domains and the voltage supply options connected to these power domains. For details about changing power modes and configuring those modes, see the [CMC](#) chapter.

### 23.2 Power domains

A power domain is a collection of circuits that can be powered off even when a voltage source is still supplied. This section shows the power domains within the device and the placement of the modules within these domains.



Figure 72. Power domains and voltage supplies

Table 150. Power domain assignments for modules

| Domain | Voltage supply | Module               |
|--------|----------------|----------------------|
| CORE   | LDO_CORE       | CM33                 |
|        |                | NVIC                 |
|        |                | Systick Timer        |
|        |                | Mutilayer AHB Matrix |
|        |                |                      |

*Table continues on the next page...*

Table 150. Power domain assignments for modules (continued)

|  |                            |
|--|----------------------------|
|  | PBridge0/1                 |
|  | DWT                        |
|  | ITM                        |
|  | TPIU                       |
|  | DAP                        |
|  | Debug Mailbox              |
|  | SWJ                        |
|  | AOI0                       |
|  | CMC                        |
|  | CDOG0                      |
|  | CRC0                       |
|  | DMA0                       |
|  | SYSCON                     |
|  | MBC                        |
|  | FMC0                       |
|  | FMU0                       |
|  | Flash                      |
|  | LPCAC                      |
|  | ROM-BOOT                   |
|  | FRO12M (Analog Circuitry)  |
|  | FRO192M (Analog Circuitry) |
|  | SCG                        |
|  | SOSC (Analog Circuitry)    |
|  | I3C0                       |
|  | LPI2C0                     |
|  | LPSPI0/1                   |
|  | LPUART0-2                  |
|  | USBFS (Digital Circuitry)  |
|  | CTIMER0-2                  |
|  | Frequency Measurement Unit |
|  | OSTIMER0                   |
|  | PWM0                       |
|  | QDC0                       |

*Table continues on the next page...*

Table 150. Power domain assignments for modules (continued)

|        |                        |                                |
|--------|------------------------|--------------------------------|
|        |                        | UTICK0                         |
|        |                        | WWDT0                          |
|        |                        | ADC0-GP (Digital Circuitry)    |
|        |                        | CMP1 (Digital Circuitry)       |
|        |                        | GPIO0-3                        |
|        |                        | PORT0-3                        |
| SRAM   | LDO_CORE / RAM_RET_LDO | Code TCM                       |
|        |                        | System TCM                     |
| SYSTEM | VDD                    | SPC0                           |
|        |                        | HVD/LVD/POR (Analog Circuitry) |
|        |                        | LDO_CORE (Analog Circuitry)    |
|        |                        | RAM_RET_LDO (Analog Circuitry) |
|        |                        | LDO_CORE (Analog Circuitry)    |
|        |                        | VBAT                           |
|        |                        | FRO16K (Analog Circuitry)      |
|        |                        | WUU                            |
|        |                        | LPTMR0                         |
|        |                        | Wake Timer                     |
|        |                        | CMP0/1 (Analog Circuitry)      |
|        |                        | CMP0 (Digital Circuitry)       |
|        |                        | PORT0-3 (Pins)                 |
| USB    | VDD_USB                | USBFS PHY (Analog Circuitry)   |
| ANALOG | VDD_ANA                | ADC0 (Analog Circuitry)        |

### 23.3 Power modes

The device supports Active, Sleep, Deep Sleep, Power down and Deep Power Down. Any reset brings the chip back to the Active mode.



Figure 73. Power modes

### 23.3.1 Active mode

In Active mode, CPU execution is possible.

To achieve the performance requirements of a given system application while minimizing power consumption, Active mode permits the following power-saving options when possible:

- Configure the VDD\_CORE subdomains voltage level to balance power and performance.
- Gate the clocks to unused modules.

### 23.3.2 Sleep mode

In the Sleep mode, the CPU clock is off, and the system clock and bus clock remain ON. Most modules can remain operational. To achieve the performance requirements of a given system application while minimizing power consumption, the Sleep mode permits the following power-saving options when possible:

- Configure the VDD\_CORE sub-domains voltage level to balance power and performance.
- Gate the clocks to unused modules.

### 23.3.3 Deep Sleep mode

In Deep Sleep mode, CPU execution is halted. The core clock is gated off.

The Deep Sleep mode supports the following behaviors based on different clock configurations:

- CPU clock, system clock and bus clock are all OFF.
- Some modules can remain operational with low power asynchronous clock sources and serve as wake-up sources.
- SRAM is in deep sleep mode.

To enter Deep Sleep mode, CMC PMCTRLMAIN[LPMODE] must be configured to 0001b, and SPC LP\_CFG[CORELDO\_VDD\_LVL] should not be configured to non-zero value.

Wake from Deep Sleep mode is triggered by an interrupt or a wakeup event.

The Deep Sleep mode also supports a partial wake-up where a bus master other than the CPU (eg. DMA) is recovered by a wakeup event. The device automatically re-enters the Deep Sleep mode after this module finishes its task.

To achieve the performance requirements of a given system application while minimizing power consumption, the Deep Sleep mode permits the following power-saving options when possible:

- Configure the VDD\_CORE subdomains voltage level to balance power and performance.
- Gate the clocks to unused modules.

### 23.3.4 Power down mode

Power down mode places CORE\_MAIN domain of the chip into a static state. It is the lowest power mode that can retain all registers. External signals can wake the chip via VDD\_SYS domain peripherals.

To enter power down mode, CMC PMCTRLMAIN[LPMODE] should be configured to 0011b, and SPC LP\_CFG[CORELDO\_VDD\_LVL] should be configured 0000b.

Flash memory is powered off. SRAM is in deep sleep mode.

The power down mode also supports a partial wake-up where a bus master other than the CPU (eg. DMA) is recovered by a wakeup event in VDD\_SYS domain. The device automatically re-enters the Power down mode after this module finishes its task.

## 23.4 Deep Power Down mode

The device wakes from Deep Power Down mode through the Reset routine.

In Deep Power Down mode, the whole VDD\_CORE domain (including all subdomains) is power gated.

In Deep Power Down mode, the on-chip regulator for VDD\_CORE is powered off. The peripherals in SYSTEM (VDD\_SYS) domain can be still alive.

External reset or the VDD\_SYS domain peripherals can wake the device.

SRAM can be retained optionally in Deep Power Down mode.

## 23.5 Module operation in low power modes

The following table shows the functionality of each module in low power modes.

| Module                | Sleep           | Deep Sleep              | Power down | Deep Power Down  |
|-----------------------|-----------------|-------------------------|------------|------------------|
| <b>Core Modules</b>   |                 |                         |            |                  |
| Bus fabric            | On <sup>1</sup> | Static <sup>2</sup>     | Static     | Off <sup>3</sup> |
| CM33                  | Static          | Static                  | Static     | Off              |
| <b>System Modules</b> |                 |                         |            |                  |
| AOI                   | On              | On                      | Static     | Off              |
| CRC                   | On              | Static                  | Static     | Off              |
| CMC                   | On              | On                      | Static     | Off              |
| eDMA3                 | On              | LP <sup>4</sup> /Static | Static     | Off              |
| EIM                   | On              | Static                  | Static     | Off              |
| ERM                   | On              | Static                  | Static     | Off              |
| MBC                   | On              | Static                  | Static     | Off              |
| Peripheral Input Mux  | On              | On/Static               | Static     | Off              |
| RMC                   | On              | On                      | On         | On               |
| SCG-Lite              | On              | On/Static               | Static     | Off              |
| SPC                   | On              | On                      | On         | On               |
| SYSCON                | On              | On/Static               | Static     | Off              |
| WUU                   | On              | On                      | On         | On               |
| VBAT Wrapper          | On              | On                      | On         | On               |

*Table continues on the next page...*

*Table continued from the previous page...*

| Module                | Sleep  | Deep Sleep | Power down                              | Deep Power Down |
|-----------------------|--------|------------|-----------------------------------------|-----------------|
| <b>Clock Source</b>   |        |            |                                         |                 |
| 40M OSC               | On/Off | On/Off     | Off                                     | Off             |
| FRO192M               | On/Off | On/Off     | Off                                     | Off             |
| FRO12M                | On     | On/Off     | Off                                     | Off             |
| FRO16K                | On/Off | On/Off     | On/Off                                  | On/Off          |
| <b>PMC Sub Module</b> |        |            |                                         |                 |
| BG                    | On     | On/Off     | Off                                     | Off             |
| LP-BG                 | On     | On         | On                                      | On/Off(?)       |
| LDO_CORE              | On     | LP/Off     | LP                                      | Off             |
| PoR                   | On     | On         | On                                      | On              |
| RAM_Retention_LDO     | On/Off | On/Off     | On/Off                                  | On/Off          |
| VDD_LVD/HVD           | On/Off | On         | Off                                     | Off             |
| VDD_LV_LVD            | On/Off | On         | Off                                     | Off             |
| VDD_USB LVD           | On/Off | On         | Off                                     | Off             |
| <b>Memory</b>         |        |            |                                         |                 |
| LPCAC                 | Static | Static     | Static                                  | Off             |
| Flash Array           | On     | Static     | Off (flash array)<br>VDD is power down) | Off             |
| FMC                   | On     | Static     | Static                                  | Off             |
| FMU                   | On     | Static     | Static                                  | Off             |
| SRAM                  | On     | Retention  | Retention                               | Retention/OFF   |
| ROM                   | On     | Static     | Static                                  | Off             |
| <b>Timers</b>         |        |            |                                         |                 |
| CDOG                  | Static | Static     | Static                                  | Off             |
| CTimer0~2             | On     | Static/LP  | Static                                  | Off             |
| FlexPWM               | On     | Static     | Static                                  | Off             |
| FME                   | On     | Static/LP  | Static                                  | Off             |
| LPTMR                 | On     | Static/LP  | Static/LP                               | Static/LP       |
| OS Event Timer        | On     | Static/LP  | Static                                  | Off             |
| uTICK                 | On     | Static/LP  | Static                                  | Off             |
| Wake Timer            | On     | Static/LP  | Static/LP                               | Static/LP       |
| WWDT                  | On     | Static/LP  | Static                                  | Off             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Module                | Sleep  | Deep Sleep | Power down | Deep Power Down |
|-----------------------|--------|------------|------------|-----------------|
| <b>Communication</b>  |        |            |            |                 |
| I3C                   | On     | Static/LP  | Static     | Off             |
| LPI2C                 | On     | Static/LP  | Static     | Off             |
| LP SPI0~1             | On     | Static/LP  | Static     | Off             |
| LPUART0~2             | On     | Static/LP  | Static     | Off             |
| USB FS                | On     | Static/LP  | Static     | Off             |
| <b>Analog</b>         |        |            |            |                 |
| 12bit HS ADC Digital  | On     | Static/LP  | Static     | Off             |
| 12bit HS ADC Analog   | On/Off | On/Off     | Static     | Off             |
| CMP0 Digital          | On     | Static/LP  | Static/LP  | Static/LP       |
| CMP0 Analog           | On/Off | On/Off     | On/Off     | On/Off          |
| CMP1 Digital          | On     | Static/LP  | Static     | Off             |
| CMP1 Analog           | On     | On/Off     | On/Off     | On/Off          |
| <b>HMI</b>            |        |            |            |                 |
| GPIO0~2               | On     | Static/LP  | Static     | Off             |
| GPIO3                 | On     | Static/LP  | Static     | Off             |
| PORT0~2               | On     | Static     | Static     | Static          |
| PORT3                 | On     | Static     | Static     | Static          |
| <b>Debug and Test</b> |        |            |            |                 |
| JTAG and SWD          | On     | Static     | Static     | Off             |
| SWO                   | On     | Static     | Static     | Off             |
| TCU                   | On     | Static     | Static     | Off             |

1. On means module is functional and accessible via memory map. For analog module, means it is enabled.
2. Static means the module is not active in state retention status.
3. Off means the module can be powered off.
4. LP means that the module is in low power state (clock gated, asynchronous operation, etc). For digital module, it can be active with async functional clock.

## 23.6 Power optimization

### 23.6.1 VDD\_CORE voltage scaling

This device supports VDD\_CORE voltage scaling for different performance and power consumption.

This device supports the following VDD\_CORE voltage scaling methods:

In Active and Sleep mode, VDD\_CORE can be configured to either 1.0 V or 1.1 V in [SPC](#). When VDD\_CORE is 1.0 V, it is Mid Drive (MD) mode. When VDD\_CORE is 1.1 V, it is Standard Drive (SD) Mode. Lower VDD\_CORE in Deep Sleep mode, can further

reduce VDD\_CORE level below 1.0 V in SPC. The leakage can be reduced. CORE\_MAIN domain can be retained, but all logics in VDD\_CORE are static. CMC[PMCTRLMAIN] (Power Mode Control) register in [CMC registers](#) must be configured to 4'b0011.

### 23.6.2 SRAM configuration

The SRAM is partitioned, allowing the mode of each SRAM partition to be independently configured:

| SRAM power mode | Description                                            |
|-----------------|--------------------------------------------------------|
| Active          | SRAM can be accessed normally.                         |
| Deep Sleep      | SRAM cannot be accessed, but the data is retained.     |
| Shutdown        | SRAM cannot be accessed, and the data is not retained. |

Depending on the requirements of the system application, software can optionally configure an individual SRAM partition to be in a lower, power-saving mode relative to the overall device power mode:

| When the overall device power mode is... | An SRAM partition may be configured into this mode... |
|------------------------------------------|-------------------------------------------------------|
| Active/Sleep                             | Active                                                |
| Deep Sleep/Power down                    | Deep Sleep                                            |
| Deep Power Down                          | Deep Sleep or Shutdown                                |

#### NOTE

SPC implements RAM\_RET\_LDO which can retain SRAM in Deep Power Down (DPD) mode. There are registers in SPC to control which SRAM can be retained in DPD mode.

### 23.6.3 Flash low power options

The internal flash memory can enter low power mode:

- in Active mode under software control (FLASHCR[FLASHDIS])
- optionally in Sleep mode (FLASHCR[FLASHDOZE])
- in Deep Sleep mode

#### NOTE

To avoid unexpected access latencies, take care when configuring the flash module to a low power mode when the overall device is in Active mode. The flash module needs time to recover full-speed functionality after entering a low power mode.

### 23.6.4 Peripheral clock gating

To conserve power, the clocks to modules can be turned off or divided by configuring the SYSCON module registers.

### 23.6.5 Voltage monitor optimization

Depending on the requirements of the system application, software can disable individual voltage monitors (LVD and/or HVD) within the different power domains to save power.

### 23.6.6 Wake-up time consideration

This device supports different low power modes for power consumption level and wake-up time balance.

The wake-up time from Sleep/Deep Sleep mode is the accumulation of following time:

- VDD\_CORE power source recovery time
- The longer of the following:
  - Clock recovery time
  - Flash recovery time
- Interrupt Latency

The wake-up time from Deep Power Down mode is the boot-up time required after POR releases the chip. This time includes everything in a cold power up, including the boot ROM latency.

These factors can affect the clock recovery time:

- The system clock source status in low-power modes. If the clock remains on in a low-power mode, no recovery time is required.
- The system clock source before entering low-power mode

The flash recovery time depends on the flash status in low power mode.

The VDD\_CORE power source recovery time can be affected by following factors:

- The regulator status in low power modes. There will be no recovery time needed if the regulator remains in full-power regulation in low power mode.
- Whether VDD\_CORE voltage scaling is enabled before and after entering low power modes

# Chapter 24

## VBAT

### 24.1 Chip-specific VBAT information

Table 151. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | VBAT           | <a href="#">VBAT</a>                |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 24.1.1 Module instances

This device contains one instance of the VBAT module, VBAT0.

#### 24.1.2 Unsupported features

This device only supports FRO16 feature of VBAT. All other features are not supported and references to RAM LDO, bandgap timer, and switch, should be ignored.

#### 24.1.3 Connections for FROCLKE[CLKE<sub>n</sub>]

Table 152. Connections for FROCLKE[CLKE<sub>n</sub>]

| VBAT clock enable | connects to this power domain |
|-------------------|-------------------------------|
| CLKE0             | VDD                           |
| CLKE1             | VDD_LV                        |

#### 24.1.4 VBAT power supply

VBAT is supplied from the chip power supply, VDD.

### 24.2 Overview

VBAT implements the 16 kHz internal clock source.

### 24.2.1 Block diagram



Figure 74. Block diagram

### 24.2.2 Features

- Supports internal 16 kHz free-running oscillator (FRO16K)

## 24.3 Functional description

The following sections describe the functional details of VBAT.

### 24.3.1 Operations

This section describes the operations of VBAT.

#### 24.3.1.1 FRO 16.384 kHz clock

FRO16K is enabled by default on POR. You can disable it or lock it to prevent any change to the enable field.

### 24.3.2 Low-power modes

VBAT remains functional in all low-power modes.

### 24.3.3 Debug mode

Debug modes do not affect VBAT.

### 24.3.4 Clocks

VBAT implements the following clock domains:

- Bus interface clock - access the registers
- FRO16 kHz internal clock

### 24.3.5 Reset

Only the POR resets VBAT.

## 24.4 Initialization

To enable and lock the FRO16K:

1. Write 1h to [FROCTLA\[FRO\\_EN\]](#).
2. Write 1h to [FROLCKA\[LOCK\]](#).
3. Alter [FROCLKE\[CLKE\]](#) to clock gate different FRO16K outputs to different peripherals to reduce power consumption.

## 24.5 Memory map and register definition

This section includes VBAT memory map and detailed descriptions of all registers.

**NOTE**

The VBAT registers are reset on VBAT Cold Reset only (VBAT POR).

### 24.5.1 VBAT register descriptions

#### 24.5.1.1 VBAT memory map

VBAT0 base address: 4009\_3000h

| Offset | Register                       | Width<br>(in bits) | Access | Reset value |
|--------|--------------------------------|--------------------|--------|-------------|
| 0h     | Version ID (VERID)             | 32                 | R      | 0101_0001h  |
| 200h   | FRO16K Control A (FROCTLA)     | 32                 | RW     | 0000_0001h  |
| 218h   | FRO16K Lock A (FROLCKA)        | 32                 | RW     | 0000_0000h  |
| 220h   | FRO16K Clock Enable (FROCLKE)  | 32                 | RW     | 0000_0000h  |
| 700h   | Wakeup 0 Register A (WAKEUP0A) | 32                 | RW     | 0000_0000h  |
| 708h   | Wakeup 0 Register A (WAKEUP1A) | 32                 | RW     | 0000_0000h  |
| 7F8h   | Wakeup Lock A (WAKLCKA)        | 32                 | RW     | 0000_0000h  |

#### 24.5.1.2 Version ID (VERID)

##### Offset

| Register | Offset |
|----------|--------|
| VERID    | 0h     |

##### Function

Records the specific version of VBAT in the chip.

##### Diagram

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

**Fields**

| Field           | Function                                                                                                                     |
|-----------------|------------------------------------------------------------------------------------------------------------------------------|
| 31-24<br>MAJOR  | Major Version Number<br>Returns the major version number for the specification.                                              |
| 23-16<br>MINOR  | Minor Version Number<br>Returns the minor version number for the specification.                                              |
| 15-0<br>FEATURE | Feature Specification Number<br>Returns the feature set number, indicating the feature set present in this instance of VBAT. |

**24.5.1.3 FRO16K Control A (FROCTLA)****Offset**

| Register | Offset |
|----------|--------|
| FROCTLA  | 200h   |

**Function**

Controls FRO16K. Writes to this register are blocked when [FROLCKA\[LOCK\]](#) is 1.

**Diagram****Fields**

| Field       | Function                                     |
|-------------|----------------------------------------------|
| 31-1<br>—   | Reserved                                     |
| 0<br>FRO_EN | FRO16K Enable<br>0b - Disable<br>1b - Enable |

#### 24.5.1.4 FRO16K Lock A (FROLCKA)

##### Offset

| Register | Offset |
|----------|--------|
| FROLCKA  | 218h   |

##### Function

Contains the lock field. Writes to this register are blocked when [FROLCKA\[LOCK\]](#) is 1.

##### Diagram



##### Fields

| Field     | Function                                                                                                                                                |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-1<br>— | Reserved                                                                                                                                                |
| 0<br>LOCK | Lock<br>Blocks any write to the FRO16K registers when you write 1 to this field.<br>VBAT POR writes 0 to this field.<br>0b - Do not block<br>1b - Block |

#### 24.5.1.5 FRO16K Clock Enable (FROCLKE)

##### Offset

| Register | Offset |
|----------|--------|
| FROCLKE  | 220h   |

##### Function

Contains clock gating register field to gate the FRO16K clock to other modules.

**NOTE**

FROCLKE cannot be locked (not affected by [FRO16K Lock A \(FROLCKA\)](#)).

**Diagram**

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

**Fields**

| Field | Function                                                                                                                                                                                        |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2  | Reserved                                                                                                                                                                                        |
| —     |                                                                                                                                                                                                 |
| 1-0   | Clock Enable                                                                                                                                                                                    |
| CLKE  | Enables the corresponding FRO16 kHz output clock to other modules when you write 1 to the corresponding bit in this field. See the chip-specific VBAT information section for more information. |

**24.5.1.6 Wakeup 0 Register A (WAKEUP0A - WAKEUP1A)****Offset**

| Register | Offset |
|----------|--------|
| WAKEUP0A | 700h   |
| WAKEUP1A | 708h   |

**Function**

Contains software writable bits. Writes to this register are blocked when WAKEUP lock register is set.

**Diagram**

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

**Fields**

| Field | Function                 |
|-------|--------------------------|
| 31-0  | Register                 |
| REG   | Software writable value. |

**24.5.1.7 Wakeup Lock A (WAKLCKA)****Offset**

| Register | Offset |
|----------|--------|
| WAKLCKA  | 7F8h   |

**Function**

Contains the lock bits. Writes to this register are blocked when Wakeup lock registers are set.

**Diagram**

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

**Fields**

| Field     | Function                                                                                                  |
|-----------|-----------------------------------------------------------------------------------------------------------|
| 31-1<br>— | Reserved                                                                                                  |
| 0<br>LOCK | Lock<br>When set, blocks writes to the Wakeup registers.<br>0b - Lock is disabled<br>1b - Lock is enabled |

# Chapter 25

## System Power Control (SPC)

### 25.1 Chip-specific SPC information

Table 153. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | SPC            | <a href="#">SPC</a>                 |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 25.1.1 Module instances

This device has one instance of the SPC module, SPC0.

#### 25.1.2 Voltage regulators

This section describes the various on-chip regulators.

Table 154. On-chip regulators

| Regulator name | Description                                                                                                                                                                                                                               |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LDO_CORE       | The LDO_CORE can be used to power VDD_CORE domain.                                                                                                                                                                                        |
| RAM_RET_LDO    | Supports four SRAM retention switches. Each switch supports up to 16KB SRAM. <ul style="list-style-type: none"> <li>• Switch 0: Retain RAM A0 and RAM X1</li> <li>• Switch 1: Retain RAM A0</li> <li>• Switch 2: Retain RAM A1</li> </ul> |

#### 25.1.3 Analog modules controlled by SOC\_CNTRL

The SOC\_CNTRL bits in both ACTIVE\_CFG1 and LP\_CFG1 registers control which analog modules are enabled/disabled in Active or Low-Power modes. The table below lists the analog modules controlled by these bits.

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21          | 20          | 19 | 18 | 17      | 16      |
|-------|----|----|----|----|----|----|----|----|----|----|-------------|-------------|----|----|---------|---------|
| R/W   |    |    |    |    |    |    |    |    |    |    | cmp1_dac_en | cmp0_dac_en |    |    | cmp1_en | cmp0_en |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0           | 0           | 0  | 0  | 0       | 0       |

  

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1            | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|--------------|---|
| R/W   |    |    |    |    |    |    |   |   |   |   |   |   |   |   | usb3v_det_en |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1            | 0 |

Figure 75. SOC\_CNTRL bits

#### 25.1.4 Low power current reference enable bit LP\_CFG[LP\_IREFEN]

The low power current reference is used by analog modules CMP0/1, and FRO12M. The bit LP\_IREFEN should be set if these analog modules are used in the Deep Power Down mode. For CMP0-1, this bit should be set if using nano mode in the Deep Power Down mode.

#### 25.1.5 Power modes

There is no VDD\_P2. Bit position 2 in EVD\_CFG register is reserved field.

#### 25.1.6 Low Power Wake-Up Delay

Table 155. LPWKUP Delay

| Regulator | LP_CFG Voltage | ACTIVE_CFG Voltage | Minimum LPWKUP_DELAY |
|-----------|----------------|--------------------|----------------------|
| LDO_CORE  | 0.6V           | 1.0V               | 0x5B                 |
| LDO_CORE  | 0.6V           | 1.1V               | 0x5B                 |
| LDO_CORE  | 1.0V           | 1.0V               | 0                    |
| LDO_CORE  | 1.0V           | 1.1V               | 0x5B                 |

## 25.2 Overview

SPC contains and controls the following components:

- One low-drop-out (LDO) voltage regulator (1.0 V LDO\_CORE)
- Circuits that monitor and assure correct voltage levels:
  - Power-on reset (POR)
  - Low-voltage detect (LVD)
  - High-voltage detect (HVD)

SPC turns these components on and off, and switches them to different power mode levels based on power-mode change requests from each of the chip power domains.

### 25.2.1 Block diagram



Figure 76. Block diagram

### 25.2.2 Features

- Selectable core internal voltage regulator (1.0 V LDO\_CORE)
- Active POR providing brown-out detect
- Low-voltage detect
- High-voltage detect
- Core power gate control

## 25.3 Functional description

### 25.3.1 Power mode transitions

Figure 77 shows the power mode state transitions available for each power-down domain. A POR or LVD reset initially returns the power-down domains to ACTIVE state.



Figure 77. Power mode state diagram

SPC allows each power domain to enter or exit low-power modes independently of the other. You must ensure that any common system resources (for example, clock sources) are always available whenever required for a power-domain current power mode. For example, if a clock source in power domain 0 drives power domain 1, you must ensure that power domain 0 does not enter a low-power mode, because that would disable the clock source.

Figure 78 defines the low-power entry and exit flow for each of the SPC power-down domains.



**Figure 78. SPC regulator power mode state diagram**

### 25.3.2 Active mode voltage updates

This section describes voltage and frequency changes in Active mode.

You can alter the operating voltage and frequency during Active mode to optimize power consumption depending on the application's performance requirements.

When increasing voltage and frequency in Active mode, you must perform the following steps:

1. Increase voltage to a new level ([ACTIVE\\_CFG\[CORELDO\\_VDD\\_LVL\]](#)).
  2. Wait for voltage change to complete ([SC\[BUSY\]](#) = 0).
  3. Configure flash memory to support higher voltage level and frequency ([MSF\\_FCTRL\[RWSC\]](#)).

4. Configure SRAM to support higher voltage levels ([SRAMCTL\[VSM\]](#)).
5. Request SRAM voltage update (write 1 to [SRAMCTL\[REQ\]](#)).
6. Wait for SRAM voltage change to complete ([SRAMCTL\[ACK\]](#) = 1).
7. Clear request for SRAM voltage change (write 0 to [SRAMCTL\[REQ\]](#)).
8. Increase frequency to a new level (for example, SCG\_RCCR).
9. You can continue execution.

When decreasing voltage and frequency in Active mode perform the following steps:

1. Decrease frequency to a new level (for example, SCG\_RCCR).
2. Configure flash memory to support lower voltage level and frequency ([MSF\\_FCTRL\[RWSC\]](#)).
3. Configure SRAM to support lower voltage levels ([SRAMCTL\[VSM\]](#)).
4. Request SRAM voltage update (write 1 to [SRAMCTL\[REQ\]](#)).
5. Wait for SRAM voltage change to complete ([SRAMCTL\[ACK\]](#) = 1).
6. Clear request for SRAM voltage change (write 0 to [SRAMCTL\[REQ\]](#)).
7. Decrease voltage to a new level ([ACTIVE\\_CFG\[CORELDO\\_VDD\\_LVL\]](#)).
8. Wait for voltage change to complete ([SC\[BUSY\]](#) = 0).
9. You can continue execution.

### 25.3.3 Low-Power Request (LPREQ) pin

The LPREQ pin asserts after low-power entry and negates after low-power wakeup.

The pin is intended to communicate with an external PMIC (for example, to enter low-power mode) or to control external switches (for example, if certain power supply rails are switched off in the low-power mode). The pin can eliminate the latency when communicating with PMIC—for example, through I<sup>2</sup>C—for quick power-state transitions. The PMIC can be configured to use the LPREQ pin to switch between two preconfigured power states.

SPC controls the state of the LPREQ pin based on how you configure [Low-Power Request Configuration \(LPREQ\\_CFG\)](#). You control the LPREQ pin in Active mode. SPC controls the pin when the chip transitions from Active to a low-power mode, and after wake-up from these power modes.

---

#### NOTE

If the power supply rails are switched off externally, software must configure the internal isolation of these power domains using the [External Voltage Domain Configuration \(EVD\\_CFG\)](#) register.

---

To use the LPREQ pin:

1. Specify the pin polarity ([LPREQ\\_CFG\[LPREQPOL\]](#)).
2. Enable the pin output ([LPREQ\\_CFG\[LPREQOE\]](#)).
3. Configure the pin mux for the desired pin using the PORT PCR registers.
4. If the external PMIC or switch needs additional time after wake-up, use [Low Power Wake-Up Delay \(LPWKUP\\_DELAY\)](#) to extend the wake-up time.

## 25.3.4 Clocks

Table 156. Clocks

| SPC component:      | Clock source          |
|---------------------|-----------------------|
| Registers and logic | Slow bus clock        |
| Delay counters      | 10 MHz internal clock |

## 25.3.5 Reset

### 25.3.5.1 Reset sources

#### 25.3.5.1.1 Power-on reset (POR)

When you initially apply power to the chip, or the supply voltage is below the POR falling threshold, the POR circuit triggers the POR condition.

The POR condition asserts a cold reset in all power domains. The SRS[POR] and SRS[LVD] status bits are both set after a POR condition.

#### 25.3.5.1.2 Low-voltage detect (LVD)

SPC supports the following LVD circuits:

- Core VDD
- System VDD

Each of these circuits is enabled by default and keeps the chip in reset until each of these supply voltages rises above the LVD rising threshold. Enabling any of the LVD circuits triggers an LVD reset condition if the corresponding supply voltage is below the LVD falling threshold.

The LVD reset condition asserts a cold reset in all power domains. The LVD- and HVD-detection logic is the only logic that HVD and LVD resets do not affect. The corresponding status fields in [Voltage Detect Status \(VD\\_STAT\)](#) become 1 after the corresponding LVD reset condition occurs.

#### 25.3.5.1.3 High-voltage detect (HVD)

SPC supports the following HVD circuit:

- System VDD

Each of these circuits is enabled by default and triggers an HVD reset condition if the corresponding supply voltage is above the HVD threshold.

Any of these reset condition asserts a cold reset in all power domains. The LVD- and HVD-detection logic is the only logic that HVD and LVD resets do not affect. The corresponding status fields in [Voltage Detect Status \(VD\\_STAT\)](#) become 1 after the corresponding HVD reset condition occurs.

### 25.3.5.2 Reset sequence

The following steps occur as part of the POR, LVD, or HVD sequence:

1. The RESET\_b pin deasserts.
2. The internal reset signals assert.
3. The POR or LVD signals negate.
4. System clocks are enabled.

### 25.3.6 Interrupts

SPC generates a single interrupt. The trigger for this interrupt comes from:

- Any of the LVD or HVD circuits when they are not configured for reset and their corresponding HVDIE or LVDIE register.

## 25.4 External signals

| Signal | Description                                                                                            | Direction |
|--------|--------------------------------------------------------------------------------------------------------|-----------|
| LPREQ  | Low-power request pin used to signal external power-management circuits for a change in supply voltage | Output    |

## 25.5 Initialization

SPC does not require any special initialization.

## 25.6 Application information

To disable Bandgap in Active or Sleep mode:

1. Disable all LVD's and HVD's in ACTIVE\_CFG[29:24]= 0x00
2. Configure LDO's to Low Drive Strength in ACTIVE\_CFG register
3. Configure ACTIVE\_CFG[BGMODE] = 0x0

To disable Bandgap in Low-Power mode:

1. Disable all LVD's and HVD's in LP\_CFG[29:24]= 0x00
2. Configure LDO's to Low Drive Strength in LP\_CFG register
3. Configure LP\_CFG[BGMODE] = 0x0

## 25.7 SPC register descriptions

Different chip reset types affect the reset of different SPC registers. Each register description provides details. See the Reset chapter for more information about the types of reset on this chip.

You may use only 32-bit writes for any writable SPC registers. 8-bit or 16-bit writes cause a transfer error.

### 25.7.1 SPC memory map

SPC0 base address: 4009\_0000h

| Offset | Register                                    | Width<br>(In bits) | Access | Reset value |
|--------|---------------------------------------------|--------------------|--------|-------------|
| 0h     | Version ID (VERID)                          | 32                 | R      | 0000_0000h  |
| 10h    | Status Control (SC)                         | 32                 | RW     | 0000_0000h  |
| 1Ch    | Low-Power Request Configuration (LPREQ_CFG) | 32                 | RW     | 0000_0000h  |
| 20h    | SPC Configuration (CFG)                     | 32                 | RW     | 0000_0000h  |
| 30h    | SPC Power Domain Mode Status (PD_STATUS0)   | 32                 | RW     | 0000_0000h  |
| 40h    | SRAM Control (SRAMCTL)                      | 32                 | RW     | 0000_0001h  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset | Register                                           | Width<br>(In bits) | Access | Reset value |
|--------|----------------------------------------------------|--------------------|--------|-------------|
| 54h    | SRAM Retention Reference Trim (SRAMRETLDO_REFTRIM) | 32                 | RW     | 0000_0017h  |
| 58h    | SRAM Retention LDO Control (SRAMRETLDO_CNTRL)      | 32                 | RW     | 0000_0F01h  |
| 100h   | Active Power Mode Configuration (ACTIVE_CFG)       | 32                 | RW     | 1310_0005h  |
| 104h   | Active Power Mode Configuration 1 (ACTIVE_CFG1)    | 32                 | RW     | 0000_0002h  |
| 108h   | Low-Power Mode Configuration (LP_CFG)              | 32                 | RW     | 0008_0004h  |
| 10Ch   | Low Power Mode Configuration 1 (LP_CFG1)           | 32                 | RW     | 0000_0002h  |
| 120h   | Low Power Wake-Up Delay (LPWKUP_DELAY)             | 32                 | RW     | 0000_0000h  |
| 124h   | Active Voltage Trim Delay (ACTIVE_VDELAY)          | 32                 | RW     | 0000_00C8h  |
| 130h   | Voltage Detect Status (VD_STAT)                    | 32                 | RW     | 0000_0000h  |
| 134h   | Core Voltage Detect Configuration (VD_CORE_CFG)    | 32                 | RW     | 0000_0001h  |
| 138h   | System Voltage Detect Configuration (VD_SYS_CFG)   | 32                 | RW     | 0000_0101h  |
| 140h   | External Voltage Domain Configuration (EVD_CFG)    | 32                 | RW     | 0000_0000h  |
| 300h   | LDO_CORE Configuration (CORELDO_CFG)               | 32                 | R      | 0000_0000h  |

### 25.7.2 Version ID (VERID)

#### Offset

| Register | Offset |
|----------|--------|
| VERID    | 0h     |

#### Function

Indicates:

- The version integrated for this instance on the chip.
- Inclusion or exclusion of several optional features.

**Diagram**

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

**Fields**

| Field           | Function                                                                                                                                        |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24<br>MAJOR  | Major Version Number                                                                                                                            |
| 23-16<br>MINOR  | Minor Version Number                                                                                                                            |
| 15-0<br>FEATURE | Feature Specification Number<br>Indicates the feature set number.<br>0000_0000_0000_0000b - Standard features<br>All other values are reserved. |

**25.7.3 Status Control (SC)****Offset**

| Register | Offset |
|----------|--------|
| SC       | 10h    |

**Function**

Indicates the current SPC status.

**Diagram**

| Bits  | 31             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22          | 21 | 20 | 19 | 18 | 17             | 16          |
|-------|----------------|----|----|----|----|----|----|----|----|-------------|----|----|----|----|----------------|-------------|
| R     | SWITC<br>H_... |    |    |    |    |    |    |    | 0  |             |    |    |    |    |                | ISO_<br>CLR |
| W     |                |    |    |    |    |    |    |    |    |             |    |    |    |    |                | W1C         |
| Reset | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0  | 0              | 0           |
| Bits  | 15             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6           | 5  | 4  | 3  | 2  | 1              | 0           |
| R     |                |    |    |    | 0  |    |    |    |    | SPC_LP_MODE |    |    | 0  | 0  | SPC_L<br>P_... | BUSY        |
| W     |                |    |    |    |    |    |    |    |    |             |    |    |    |    |                | W1C         |
| Reset | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0  | 0              | 0           |

**Fields**

| Field                  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>SWITCH_STAT<br>E | Power Switch State<br><br>Indicates the power switch state.<br><br>0b - Off<br>1b - On                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 30-17<br>—             | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 16<br>ISO_CLR          | Isolation Clear Flags<br><br>Indicates whether certain peripherals and I/O pads are in a latched state as a result of having been in PDOWN mode.<br><br>Each bit of this field is a flag associated with a module on this chip. See the chip-specific SPC information for the module-bit association. For each flag: <ul style="list-style-type: none"><li>• A value of 0 means that peripherals and I/O pads are in the normal run state.</li><li>• A value of 1 means that peripherals and I/O pads can retain their state in their power domain.</li></ul> If a flag in this field is 1, writing 1 to that flag clears the flag and releases the I/O pads and peripherals to their normal run-mode state.<br><br>After recovering from a power-down mode, you must restore the chip configuration before clearing a flag in this field. In particular, you must restore the pin configuration for enabled WUU wake-up to avoid any WUU flag from being falsely set when the associated ISO_CLR flag is cleared.<br><br>This field resets after a system reset. |
| 15-8<br>—              | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 7-4                    | Power Domain Low-Power Mode Request<br><br>Indicates the last low-power mode that the power domain requested.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SPC_LP_MODE     | 0000b - Sleep mode with system clock running<br>0001b - DSLEEP with system clock off<br>0010b - PDOWN with system clock off<br>0100b - Reserved<br>1000b - DPDOWN with system clock off                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 3<br>—          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2<br>—          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1<br>SPC_LP_REQ | SPC Power Mode Configuration Status Flag<br>Indicates when all power-down domains requested low-power mode and SPC entered a low-power state.<br><div style="text-align: center;"> <b>NOTE</b><br/>           This field behaves differently for register reads and writes.         </div> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - SPC is in Active or Sleep mode; the ACTIVE_CFG register has control</li> <li>1b - All power domains requested low-power mode; SPC entered a low-power state; power-mode configuration based on the LP_CFG register</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul> |
| 0<br>BUSY       | SPC Busy Status Flag<br>Indicates whether SPC is busy.<br>SPC sets this flag: <ul style="list-style-type: none"> <li>• When SPC executes any type of power mode transition in Active mode or any of the chip low-power modes.</li> <li>• Due to <a href="#">LP_CFG[CORELDO_VDD_LVL]</a> changes while in Active mode.</li> </ul> <div style="text-align: center;"> <b>NOTE</b><br/>           Wait until this flag is clear before changing power-mode configuration registers.         </div> <p>0b - Not busy<br/>1b - Busy</p>                                                                                                                                                                          |

### 25.7.4 Low-Power Request Configuration (LPREQ\_CFG)

#### Offset

| Register  | Offset |
|-----------|--------|
| LPREQ_CFG | 1Ch    |

#### Function

Configures the low-power output request pin.

The register resets only after a POR, LVD, or HVD event.

#### Diagram



#### Fields

| Field    | Function                                                                                                                                                                    |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-26    | Reserved                                                                                                                                                                    |
| —        |                                                                                                                                                                             |
| 25-4     | Reserved                                                                                                                                                                    |
| —        |                                                                                                                                                                             |
| 3-2      | Low-Power Request Output Override                                                                                                                                           |
| LPREQOV  | Forces the low-power request pin high.<br>00b - Not forced<br>01b - Reserved<br>10b - Forced low (ignore LPREQPOL settings)<br>11b - Forced high (ignore LPREQPOL settings) |
| 1        | Low-Power Request Output Pin Polarity Control                                                                                                                               |
| LPREQPOL | Controls the true polarity of the low-power request output pin.                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                    |
|--------------|-------------------------------------------------------------------------------------------------------------|
|              | 0b - High<br>1b - Low                                                                                       |
| 0<br>LPREQOE | Low-Power Request Output Enable<br>Enables the low-power request output pin.<br>0b - Disable<br>1b - Enable |

## 25.7.5 SPC Configuration (CFG)

### Offset

| Register | Offset |
|----------|--------|
| CFG      | 20h    |

### Function

Controls the features of the integrated power switch that you can use to gate board-level supplies.

The register resets only after a POR, LVD, or HVD event.

### Diagram



### Fields

| Field     | Function                               |
|-----------|----------------------------------------|
| 31-4<br>— | Reserved                               |
| 3         | Integrated Power Switch Wake-up Enable |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                                     | Function                                                                                                                                                                                                                                           |
|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INTG_PWSWT<br>CH_WKUP_AC<br>TIVE_EN       | <p>Enables the switch in Active mode.</p> <p>When this field is 1, SPC asserts an output pin in Active mode to ungate the switch.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                          |
| 2<br>INTG_PWSWT<br>CH_SLEEP_AC<br>TIVE_EN | <p>Integrated Power Switch Active Enable</p> <p>Enables the switch in Active mode.</p> <p>When this field is 1, SPC asserts an output pin in Active mode to ungate the switch.</p> <p>0b - Disable<br/>1b - Enable</p>                             |
| 1<br>INTG_PWSWT<br>CH_WKUP_EN             | <p>Integrated Power Switch Wake-up Enable</p> <p>Enables the switch after wake-up from a low-power mode.</p> <p>When this field is 1, SPC asserts an output pin at low-power wake-up to ungate the switch.</p> <p>0b - Disable<br/>1b - Enable</p> |
| 0<br>INTG_PWSWT<br>CH_SLEEP_EN            | <p>Integrated Power Switch Sleep Enable</p> <p>Enables the switch in Sleep mode.</p> <p>When this field is 1, SPC asserts an output pin at low-power entry to power-gate the switch.</p> <p>0b - Disable<br/>1b - Enable</p>                       |

## 25.7.6 SPC Power Domain Mode Status (PD\_STATUS0)

### Offset

| Register   | Offset |
|------------|--------|
| PD_STATUS0 | 30h    |

### Function

Indicates power mode status for each of the SPC power domains. See the chip-specific SPC information to determine which power domains are associated with this register.

**Diagram**

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23      | 22 | 21 | 20 | 19         | 18 | 17 | 16         |
|-------|----|----|----|----|----|----|----|----|---------|----|----|----|------------|----|----|------------|
| R     |    |    |    |    |    |    |    |    | 0       |    |    |    |            |    |    |            |
| W     |    |    |    |    |    |    |    |    |         |    |    |    |            |    |    |            |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0  | 0  | 0  | 0          | 0  | 0  | 0          |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7       | 6  | 5  | 4  | 3          | 2  | 1  | 0          |
| R     |    |    |    |    | 0  |    |    |    | LP_MODE |    |    | 0  | PD_LP_R... | 0  |    | PWR_REQ... |
| W     |    |    |    |    |    |    |    |    |         |    |    |    | W1C        |    |    |            |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0  | 0  | 0  | 0          | 0  | 0  | 0          |

**Fields**

| Field                | Function                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-12<br>—           | Reserved                                                                                                                                                                                                                                                                                                                                                                          |
| 11-8<br>LP_MODE      | <p>Power Domain Low Power Mode Request</p> <p>Indicates the last low-power mode that the power domain requested.</p> <ul style="list-style-type: none"> <li>0000b - SLEEP with system clock running</li> <li>0001b - DSLEEP with system clock off</li> <li>0010b - PDOWN with system clock off</li> <li>0100b - Reserved</li> <li>1000b - DPDOWN with system clock off</li> </ul> |
| 7-5<br>—             | Reserved                                                                                                                                                                                                                                                                                                                                                                          |
| 4<br>PD_LP_REQ       | <p>Power Domain Low Power Request Flag</p> <p>Set when low power mode was requested by Power Domain since last cleared by software.</p> <ul style="list-style-type: none"> <li>0b - Did not request</li> <li>1b - Requested</li> </ul>                                                                                                                                            |
| 3-1<br>—             | Reserved                                                                                                                                                                                                                                                                                                                                                                          |
| 0<br>PWR_REQ_ST_ATUS | <p>Power Request Status Flag</p> <p>Indicates whether the power domain requested low-power mode.</p> <ul style="list-style-type: none"> <li>0b - Did not request</li> <li>1b - Requested</li> </ul>                                                                                                                                                                               |

### 25.7.7 SRAM Control (SRAMCTL)

#### Offset

| Register | Offset |
|----------|--------|
| SRAMCTL  | 40h    |

#### Function

Configures the SRAM timing for different voltage levels.

When transitioning between two voltage levels, you must keep the SRAM timing at the lowest voltage level until the voltage change is complete.

#### Diagram



#### Fields

| Field     | Function                                                                                                                                                                                                                 |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>ACK | SRAM Voltage Update Request Acknowledge<br>Indicates whether SPC acknowledged the request for an SRAM trim-value change.<br>0b - Not acknowledged<br>1b - Acknowledged                                                   |
| 30<br>REQ | SRAM Voltage Update Request<br>Allows you to request an SRAM trim value change.<br>After requesting the change, you must wait for the ACK field to become 1, then write 0 to REQ.<br>0b - Do not request<br>1b - Request |
| 29-2<br>— | Reserved                                                                                                                                                                                                                 |
| 1-0       | Voltage Select Margin                                                                                                                                                                                                    |

Table continues on the next page...

*Table continued from the previous page...*

| Field | Function                                                                                                                                   |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------|
| VSM   | Specifies the operating voltage for the SRAM's read/write timing margin.<br>00b - Reserved<br>01b - 1.0 V<br>10b - 1.1 V<br>11b - Reserved |

### 25.7.8 SRAM Retention Reference Trim (SRAMRETLDO\_REFTRIM)

#### Offset

| Register           | Offset |
|--------------------|--------|
| SRAMRETLDO_REFTRIM | 54h    |

#### Function

Specifies the trim for the SRAM retention regulator reference.

#### Diagram



#### Fields

| Field          | Function                                                                   |
|----------------|----------------------------------------------------------------------------|
| 31-5           | Reserved                                                                   |
| 4-0<br>REFTRIM | Reference Trim. Voltage range is around 0.48V - 0.85V. Trim step is 12 mV. |

### 25.7.9 SRAM Retention LDO Control (SRAMRETLDO\_CNTRL)

#### Offset

| Register         | Offset |
|------------------|--------|
| SRAMRETLDO_CNTRL | 58h    |

#### Function

Controls the SRAM retention LDO operation.

#### Diagram



#### Fields

| Field                   | Function                                                                                                                                                                                                                                                                                                              |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-12<br>—              | Reserved                                                                                                                                                                                                                                                                                                              |
| 11-8<br>SRAM_RET_E<br>N | SRAM Retention<br>Configures the retention of each SRAM array in low-power modes.<br>When SRAMLDO_ON is 1, you must retain at least one SRAM array.<br>When SRAMLDO_ON is 0, SRAM_RET_EN specifies whether the SRAM array remains powered from VDD_CORE.<br>See the chip-specific SPC information for SRAM retention. |
| 7-1<br>—                | Reserved                                                                                                                                                                                                                                                                                                              |
| 0<br>SRAMLDO_ON         | SRAM LDO Regulator Enable<br>0b - Disable<br>1b - Enable                                                                                                                                                                                                                                                              |

### 25.7.10 Active Power Mode Configuration (ACTIVE\_CFG)

#### Offset

| Register   | Offset |
|------------|--------|
| ACTIVE_CFG | 100h   |

#### Function

Controls the SPC regulators settings in the Active and Sleep power mode.

Changes to the drive strength or voltage level for any of the LDOs sets the **SC[BUSY]** flag until SPC changes its state to the new value.

#### NOTE

The LVDE and HVDE fields reset only with a POR. All other fields reset only with a system reset.

#### Diagram

| Bits  | 31 | 30 | 29   | 28 | 27 | 26 | 25   | 24     | 23     | 22 | 21 | 20     | 19         | 18 | 17   | 16     |
|-------|----|----|------|----|----|----|------|--------|--------|----|----|--------|------------|----|------|--------|
| R     | 0  | 0  | SYS_ |    | 0  | 0  | SYS_ | CORE   | VDD_   | 0  |    | BGMODE | 0          | 0  | 0    | 0      |
| W     |    |    | HVDE |    |    |    | LVDE | _LV... | VD_... |    |    |        |            |    |      |        |
| Reset | 0  | 0  | 0    | 1  | 0  | 0  | 1    | 1      | 0      | 0  | 0  | 1      | 0          | 0  | 0    | 0      |
| Bits  | 15 | 14 | 13   | 12 | 11 | 10 | 9    | 8      | 7      | 6  | 5  | 4      | 3          | 2  | 1    | 0      |
| R     | 0  | 0  | 0    | 0  | 0  | 0  | 0    | 0      | 0      | 0  | 0  | 0      | CORELDO_VD | 0  | CORE | LDO... |
| W     |    |    |      |    |    |    |      |        |        |    |    |        | D_LVL      |    |      |        |
| Reset | 0  | 0  | 0    | 0  | 0  | 0  | 0    | 0      | 0      | 0  | 0  | 0      | 0          | 1  | 0    | 1      |

#### Fields

| Field          | Function                                                                                                                                                                                                                                                              |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30<br>—     | Reserved                                                                                                                                                                                                                                                              |
| 29<br>—        | Reserved                                                                                                                                                                                                                                                              |
| 28<br>SYS_HVDE | <p>System High-Voltage Detection Enable</p> <p>Enables the system high-voltage detection.</p> <p>When SYS_HVDE = 1, you must write a value to <b>BGMODE</b> that enables the bandgap.</p> <p>Only a POR resets this field.</p> <p>0b - Disable</p> <p>1b - Enable</p> |

Table continues on the next page...

*Table continued from the previous page...*

| Field                    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27<br>—                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 26<br>—                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 25<br>SYS_LVDE           | <p>System Low-Voltage Detection Enable</p> <p>Enables the system low-voltage detection.</p> <p>When SYS_LVDE = 1, you must write a value to <a href="#">BGMODE</a> that enables the bandgap.</p> <p>Only a POR resets this field.</p> <ul style="list-style-type: none"> <li>0b - Disable</li> <li>1b - Enable</li> </ul>                                                                                                                                                            |
| 24<br>CORE_LVDE          | <p>Core Low-Voltage Detection Enable</p> <p>Enables the core low-voltage detection.</p> <p>When CORE_LVDE = 1, you must write a value to <a href="#">BGMODE</a> that enables the bandgap.</p> <p>Only a POR resets this field.</p> <ul style="list-style-type: none"> <li>0b - Disable</li> <li>1b - Enable</li> </ul>                                                                                                                                                               |
| 23<br>VDD_VD_DISA<br>BLE | <p>VDD Voltage Detect Disable</p> <p>Disables VDD voltage detect. Mask all LVDs and HVDs when you change the active voltage levels. If this field is 1, it will not mask and allow LVDs and HVDs conditions to generate a system reset or interrupt. If this field is 0, it will mask all LVDs and HVDs when changing the regulator voltage levels during Active mode.</p> <ul style="list-style-type: none"> <li>0b - Enable</li> <li>1b - Disable</li> </ul>                       |
| 22<br>—                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 21-20<br>BGMODE          | <p>Bandgap Mode</p> <p>Specifies the bandgap mode configuration.</p> <p>BGMODE will be set to 01b to keep the Bandgap enabled if a write to disable Bandgap is detected while keeping any of the regulators in normal drive strength or if any of the LVD/HVDs are kept enabled.</p> <ul style="list-style-type: none"> <li>00b - Bandgap disabled</li> <li>01b - Bandgap enabled, buffer disabled</li> <li>10b - Bandgap enabled, buffer enabled</li> <li>11b - Reserved</li> </ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19<br>—                    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 18<br>—                    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 17-13<br>—                 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 12<br>—                    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 11-10<br>—                 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 9-8<br>—                   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 7<br>—                     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 6<br>—                     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5<br>—                     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4<br>—                     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3-2<br>CORELDO_VD<br>D_LVL | <p>LDO_CORE VDD Regulator Voltage Level</p> <p><b>NOTE</b></p> <p>LDO_CORE overdrive voltage level (1.2V) is not supported when LDO_CORE is configured for low drive.</p> <p>Selects the LDO_CORE VDD regulator level.</p> <p>If the CORELDO_VDD_DS fields are set to the same value in both the ACTIVE_CFG and LP_CFG registers, the CORELDO_VDD_LVL's in the ACTIVE_CFG and LP_CFG register must be set to the same voltage level settings.</p> <p>You can change the core VDD levels for the LDO_CORE low power regulator only when CORELDO_VDD_DS=1.</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                   | Function                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | <p>When switching CORELDO_VDD_DS from low to normal drive strength, ensure the LDO_CORE high VDD_LVL setting is set to the same level that was set prior to switching to the LDO_CORE drive strength (CORELDO_VDD_DS). Otherwise, if the LVDs are enabled, an unexpected LVD can occur.</p> <p>00b - Reserved<br/>01b - Regulate to mid voltage (1.0 V)<br/>10b - Regulate to normal voltage (1.1 V)<br/>11b - Reserved</p> |
| 1<br>—                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0<br>CORELDO_VD<br>D_DS | <p>LDO_CORE VDD Drive Strength<br/>Selects the LDO_CORE VDD regulator drive strength</p> <p><b>NOTE</b><br/>When setting CORELDO_VDD_DS to Normal, BGMODE must be programmed to a value that enables the Bandgap.<br/>Writes to set drive strength to Low will be ignored if LVD/HVDs are kept enabled.</p> <p>0b - Low<br/>1b - Normal</p>                                                                                 |

### 25.7.11 Active Power Mode Configuration 1 (ACTIVE\_CFG1)

#### Offset

| Register    | Offset |
|-------------|--------|
| ACTIVE_CFG1 | 104h   |

#### Function

Enables different analog modules in Active or Sleep mode. To see what analog modules each of these bits are controlling, see the chip-specific SPC information.

**Diagram**

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

**Fields**

| Field     | Function                                                                                                                                                                                                                                        |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SOC_CNTRL | <p>Active Config Chip Control</p> <p>Enables analog modules in Active or Sleep mode.</p> <p>Bit combinations with 0: The associated analog modules are disabled.</p> <p>Bit combinations with 1: The associated analog modules are enabled.</p> |

**25.7.12 Low-Power Mode Configuration (LP\_CFG)****Offset**

| Register | Offset |
|----------|--------|
| LP_CFG   | 108h   |

**Function**

Controls the SPC regulator settings in Deep Sleep, Power Down, and Deep Power Down modes.

This register resets only after a POR or LVD event.

**Diagram**

| Bits  | 31 | 30 | 29           | 28 | 27 | 26 | 25           | 24             | 23             | 22 | 21     | 20 | 19                  | 18 | 17 | 16             |
|-------|----|----|--------------|----|----|----|--------------|----------------|----------------|----|--------|----|---------------------|----|----|----------------|
| R     | 0  | 0  | SYS_<br>HVDE |    | 0  | 0  | SYS_<br>LVDE | CORE<br>_LV... | LP_IR<br>EF... | 0  | BGMODE |    | SRAM<br>LDO...      | 0  | 0  | 0              |
| W     |    |    |              |    |    |    |              |                |                |    |        |    |                     |    |    |                |
| Reset | 0  | 0  | 0            | 0  | 0  | 0  | 0            | 0              | 0              | 0  | 0      | 0  | 1                   | 0  | 0  | 0              |
| Bits  | 15 | 14 | 13           | 12 | 11 | 10 | 9            | 8              | 7              | 6  | 5      | 4  | 3                   | 2  | 1  | 0              |
| R     | 0  | 0  |              |    | 0  |    | 0            |                | 0              | 0  |        | 0  | CORELDO_VD<br>D_LVL | 0  |    | CORE<br>LDO... |
| W     |    |    |              |    |    |    |              |                |                |    |        |    |                     |    |    |                |
| Reset | 0  | 0  | 0            | 0  | 0  | 0  | 0            | 0              | 0              | 0  | 0      | 0  | 0                   | 1  | 0  | 0              |

**Fields**

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 29<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 28<br>SYS_HVDE  | <p>System High Voltage Detect Enable</p> <p>This field resets only after a POR, LVD, or HVD event.</p> <p>When SYS_HVDE = 1, you must use <a href="#">LP_CFG[BGMODE]</a> to enable the bandgap. If you enable the bandgap to support voltage detection, the low-power mode Idd increases.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                        |
| 27<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 26<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 25<br>SYS_LVDE  | <p>System Low Voltage Detect Enable</p> <p>This field resets only after a POR, LVD, or HVD event.</p> <p>When SYS_LVDE = 1, you must use <a href="#">LP_CFG[BGMODE]</a> to enable the bandgap. If you enable the bandgap to support voltage detection, the low-power mode Idd increases.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                         |
| 24<br>CORE_LVDE | <p>Core Low Voltage Detect Enable</p> <p>This field resets only after a POR, LVD, or HVD event.</p> <p>When CORE_LVDE = 1, you must use <a href="#">LP_CFG[BGMODE]</a> to enable the bandgap. If you enable the bandgap to support voltage detection, the low-power mode Idd increases.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                          |
| 23<br>LP_IREFEN | <p>Low-Power IREF Enable</p> <p>You can disable the low-power IREF only in DPDOWN mode. In all other low-power modes, writing 1 to this field has no effect and the low-power IREF is always enabled.</p> <p>See the chip-specific SPC information for the modules that require the low-power IREF to be enabled in DPDOWN mode when you use the module in DPDOWN mode.</p> <p>0b - Disable for power saving in Deep Power Down mode<br/>1b - Enable</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22<br>—                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 21-20<br>BGMODE          | <p>Bandgap Mode</p> <p>Specifies the bandgap mode configuration.</p> <p>BGMODE will be set to 01b to keep the Bandgap enabled if a write to disable Bandgap is detected while keeping any of the regulators in normal drive strength or if any of the LVD/HVDs are kept enabled.</p> <ul style="list-style-type: none"> <li>00b - Bandgap disabled</li> <li>01b - Bandgap enabled, buffer disabled</li> <li>10b - Bandgap enabled, buffer enabled</li> <li>11b - Reserved</li> </ul> |
| 19<br>SRAMLDO_DP<br>D_ON | <p>SRAM_LDO Deep Power Low Power IREF Enable</p> <p>When set keeps the retention SRAM</p> <p><b>NOTE</b><br/>See the chip specific section for the modules that require the low power IREF to be enabled in DPDOWN mode, if the module is being used in DPDOWN mode.</p> <ul style="list-style-type: none"> <li>0b - Low Power IREF is disabled for power saving in Deep Power Down mode</li> <li>1b - Low Power IREF is enabled</li> </ul>                                          |
| 18<br>—                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 17<br>—                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 16<br>—                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 15-13<br>—               | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 12<br>—                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 11-10<br>—               | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 9-8<br>—                 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>—                     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 6-5<br>—                   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 4<br>—                     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3-2<br>CORELDO_VD<br>D_LVL | <p>LDO_CORE VDD Regulator Voltage Level</p> <p>Specifies the LDO_CORE VDD regulator level for low-power sleep modes.</p> <p><b>NOTE</b><br/>LDO_CORE overdrive voltage level (1.2V) is not supported when LDO_CORE is configured for low drive.</p> <p>If the CORELDO_VDD_DS fields are set to the same value in both the ACTIVE_CFG and LP_CFG registers, the CORELDO_VDD_LVL's in the ACTIVE_CFG and LP_CFG register must be set to the same voltage level settings.</p> <p>You can change the core VDD levels for the LDO_CORE low power regulator only when CORELDO_VDD_DS=1. So, before entering any of the low-power states (SLEEP, DSLEEP, PDOWN) with LDO_CORE low power regulator selected (LP_CFG[CORELDO_VDD_DS] = 0), you must use CORELDO_VDD_LVL to select the correct regulation level during ACTIVE run mode.</p> <p>Updating CORELDO_VDD_LVL sets the <a href="#">SC[BUSY]</a> flag. That flag remains set for at least the total time delay that <a href="#">Active Voltage Trim Delay (ACTIVE_VDELAY)</a> specifies.</p> <p>Before changing CORELDO_VDD_LVL, you must wait until the SC[BUSY] flag clears before entering the selected low-power sleep mode. This ensures the correct core VDD voltage levels are set after the chip is in the chosen mode.</p> <ul style="list-style-type: none"> <li>00b - Retention voltage</li> <li>01b - Mid voltage (1.0 V)</li> <li>10b - Normal voltage (1.1 V)</li> <li>11b - Reserved</li> </ul> |
| 1<br>—                     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0<br>CORELDO_VD<br>D_DS    | <p>LDO_CORE VDD Drive Strength</p> <p>Specifies the drive strength of the LDO_CORE VDD regulator.</p> <p>The LDO_CORE regulator is forced to disabled in DPDOWN Sleep mode.</p> <p>If you specify normal drive strength, you must write a value to <a href="#">LP[BGMODE]</a> that enables the bandgap.</p> <p>If you have enabled LVDs or HVDs, and attempt to specify low drive strength, SPC ignores the attempt.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function    |
|-------|-------------|
|       | 0b - Low    |
|       | 1b - Normal |

### 25.7.13 Low Power Mode Configuration 1 (LP\_CFG1)

#### Offset

| Register | Offset |
|----------|--------|
| LP_CFG1  | 10Ch   |

#### Function

Enables different analog modules in Deep Sleep, Power Down, or Deep Power Down modes.

See the chip-specific SPC information for a list of analog modules that this register controls.

#### Diagram

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

#### Fields

| Field             | Function                                                                                                                                                                                                                                                             |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>SOC_CNTRL | Low-Power Configuration Chip Control<br>Provides control bits to the chip to enable analog modules in Low Power mode.<br>Bit combinations with 0: The associated analog modules are disabled.<br>Bit combinations with 1: The associated analog modules are enabled. |

### 25.7.14 Low Power Wake-Up Delay (LPWKUP\_DELAY)

#### Offset

| Register     | Offset |
|--------------|--------|
| LPWKUP_DELAY | 120h   |

#### Function

Works with the LPREQ pin to extend the wake-up time if the external PMIC or switch needs additional time after wake-up.

#### Diagram

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

#### Fields

| Field                | Function                                                                                                                                                                                                                                                                                                                           |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—           | Reserved                                                                                                                                                                                                                                                                                                                           |
| 15-0<br>LPWKUP_DELAY | <p>Low-Power Wake-Up Delay</p> <p>Specifies the number of SPC timer clock cycles that SPC waits after exiting low-power modes.</p> <p>This field resets only after a POR, LVD, or HVD event.</p> <p>When voltage levels are not the same between ACTIVE mode and Low Power mode, you must write a nonzero value to this field.</p> |

### 25.7.15 Active Voltage Trim Delay (ACTIVE\_VDELAY)

#### Offset

| Register      | Offset |
|---------------|--------|
| ACTIVE_VDELAY | 124h   |

#### Function

Specifies the delay due to voltage level changes to the regulators in Active mode.

This register resets only after a POR event.

SPC loads the ACTIVE\_VDELAY values are loaded from IFR or FUSE after any reset. NXP trims this reset value for the recommended wait time.

#### Diagram

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

#### Fields

| Field                 | Function                                                                                                                                             |
|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—            | Reserved                                                                                                                                             |
| 15-0<br>ACTIVE_VDELAY | Active Voltage Delay<br>Specifies the number of SPC timer clock cycles that SPC waits when changing the core-regulator voltage level in Active mode. |

#### 25.7.16 Voltage Detect Status (VD\_STAT)

##### Offset

| Register | Offset |
|----------|--------|
| VD_STAT  | 130h   |

##### Function

Displays the LVD or HVD captured for:

- Core VDD.
- System VDD.
- IO VDD.

This register resets only after a POR event.

**Diagram**

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22             | 21 | 20 | 19 | 18             | 17             | 16 |
|-------|----|----|----|----|----|----|----|----|----|----------------|----|----|----|----------------|----------------|----|
| R     |    |    |    |    |    |    |    |    | 0  |                |    |    |    |                |                |    |
| W     |    |    |    |    |    |    |    |    |    |                |    |    |    |                |                |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0              | 0  | 0  | 0  | 0              | 0              | 0  |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6              | 5  | 4  | 3  | 2              | 1              | 0  |
| R     |    |    |    |    | 0  |    |    |    | 0  | SYSV<br>DD.... | 0  | 0  | 0  | SYSV<br>DD.... | CORE<br>VDD... |    |
| W     |    |    |    |    |    |    |    |    |    | W1C            |    |    |    | W1C            | W1C            |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0              | 0  | 0  | 0  | 0              | 0              | 0  |

**Fields**

| Field                | Function                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—           | Reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| 15-7<br>—            | Reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| 6<br>—               | Reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| 5<br>SYSVDD_HVD<br>F | <p>System HVD Flag</p> <p>Indicates a system HVD event.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - Event not detected</li> <li>1b - Event detected</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul> |
| 4<br>—               | Reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| 3<br>—               | Reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| 2                    | Reserved                                                                                                                                                                                                                                                                                                                                                                                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                 | Function                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —                     |                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1<br>SYSVDD_LVDF      | <p>System Low-Voltage Detect Flag<br/>Indicates a system LVD event.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - Event not detected</li> <li>1b - Event detected</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul> |
| 0<br>COREVDD_LV<br>DF | <p>Core Low-Voltage Detect Flag<br/>Indicates a core LVD event.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - Event not detected</li> <li>1b - Event detected</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul>     |

### 25.7.17 Core Voltage Detect Configuration (VD\_CORE\_CFG)

#### Offset

| Register    | Offset |
|-------------|--------|
| VD_CORE_CFG | 134h   |

#### Function

Provides these functions:

- Configures the low-voltage trip point.
- Enables the core LVD reset and interrupts.

This register resets only after a POR event.

**NOTE**

If you write 1 to both LVDRE and LVDIE, SPC generates an interrupt after exiting from LVDRE reset. If you don't want this to occur, configure the LVD or HVD so only one is enabled.

**Diagram**

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17    | 16     |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------|--------|
| R     |    |    |    |    |    |    |    | 0  |    |    |    |    |    |    |       | LOCK   |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |        |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0      |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1     | 0      |
| R     |    |    |    |    | 0  |    |    |    |    |    |    |    | 0  |    | LVDIE | LVDR E |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |       |        |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 1      |

**Fields**

| Field      | Function                                                                                                                                                                                                                        |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-17<br>— | Reserved                                                                                                                                                                                                                        |
| 16<br>LOCK | Core Voltage Detect Reset Enable Lock<br>Allows writing to the LVDRE and HVDRE fields.<br>0b - Allow<br>1b - Deny                                                                                                               |
| 15-4<br>—  | Reserved                                                                                                                                                                                                                        |
| 3-2<br>—   | Reserved                                                                                                                                                                                                                        |
| 1<br>LVDIE | Core LVD Interrupt Enable<br>Enables the Core LVD (COREVDD_LVDF) event to generate a hardware interrupt.<br>If you write 1 to LVDIE with LVDF set, SPC automatically generates an LVD interrupt.<br>0b - Disable<br>1b - Enable |
| 0<br>LVDRE | Core LVD Reset Enable<br>Enables the core LVD (COREVDD_LVDF) event to generate a hardware reset.<br>Before writing to this field, you must write 0 to <b>LOCK</b> .                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function     |
|-------|--------------|
|       | 0b - Disable |
|       | 1b - Enable  |

### 25.7.18 System Voltage Detect Configuration (VD\_SYS\_CFG)

#### Offset

| Register   | Offset |
|------------|--------|
| VD_SYS_CFG | 138h   |

#### Function

Provides these functions:

- Configures the low-voltage trip point.
- Enables the system LVD reset and interrupts.

This register resets only after a POR event.

#### NOTE

If you write 1 to both LVDRE and LVDIE, SPC generates an interrupt after exiting from LVDRE reset. If you don't want this to occur, configure the LVD or HVD so only one is enabled.

#### Diagram



#### Fields

| Field | Function |
|-------|----------|
| 31-17 | Reserved |
| —     |          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16<br>LOCK | <p>System Voltage Detect Reset Enable Lock</p> <p>Allows writing to the LVDRE, HVDRE, and LVSEL fields.</p> <p>0b - Allow<br/>1b - Deny</p>                                                                                                                                                                                                                                                                                                             |
| 15-10<br>— | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 9<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 8<br>LVSEL | <p>System Low-Voltage Level Select</p> <p>Specifies the LVD trip-point level for the system monitor. See the chip data sheet for the normal- and safe-level values.</p> <p>Before writing to this field, you must write 0 to <a href="#">LOCK</a>.</p> <p>If you want to change LVSEL, you must do this after disabling the LVD reset and interrupt. Otherwise, SPC could generate an LVD due to the LVSEL change.</p> <p>0b - Normal<br/>1b - Safe</p> |
| 7-4<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3<br>HVDIE | <p>System HVD Interrupt Enable</p> <p>Enables the system HVD (SYSVDD_HVDF) event to generate a hardware interrupt.</p> <p>If you write 1 to HVDIE with HVDF set, SPC automatically generates an HVD interrupt.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                  |
| 2<br>HVDRE | <p>System HVD Reset Enable</p> <p>Enables the system HVD (SYSVDD_HVDF) event to generate a hardware reset.</p> <p>Before writing to this field, you must write 0 to <a href="#">LOCK</a>.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                       |
| 1<br>LVDIE | <p>System LVD Interrupt Enable</p> <p>Enables the system LVD (SYSVDD_LVDF) event to generate a hardware interrupt.</p> <p>If you write 1 to LVDIE with LVDF set, SPC automatically generates an LVD interrupt.</p>                                                                                                                                                                                                                                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                       |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | 0b - Disable<br>1b - Enable                                                                                                                                                                                    |
| 0<br>LVDRE | System LVD Reset Enable<br>Enables the system LVD (SYSVDD_LVDF) event to generate a hardware reset.<br>Before writing to this field, you must write 0 to <a href="#">LOCK</a> .<br>0b - Disable<br>1b - Enable |

### 25.7.19 External Voltage Domain Configuration (EVD\_CFG)

#### Offset

| Register | Offset |
|----------|--------|
| EVD_CFG  | 140h   |

#### Function

Isolates signals from external voltage domains under certain conditions.

Chip pins supply the external voltage domains. These domains are controlled at the board level. This register allows you to control internal isolations for signals from these domains if either of the following conditions is true:

- They are not powered on the board.
- They are powered off externally in low-power modes (using the SPC\_LPREQ pin).

Any logic in the isolated voltage domain also resets, because the voltage domain is assumed to be powered off. This reset does not impact any VDD\_CORE internal power domains or registers—only I/O pads, analog components, or both.

This register resets only after a POR event.

Each bit of the EVDISO, EVDLISO, and EVDSTAT fields corresponds to one of the I/O or analog supplies according to [Table 157](#).

**Table 157. Mapping of bits to supplies**

| Bit position in field | Description |
|-----------------------|-------------|
| 0                     | VDD         |
| 1                     | VDD_USB     |
| 2                     | VDD_P2      |

#### NOTE

Bit 0 VDD should not be set in EVD\_CFG[EVDISO] and it should only be set in EVD\_CFG[EVDLISO] when moving to Deep Power Down mode

**Diagram**

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18             | 17 | 16      |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------|----|---------|
| R     |    |    |    |    |    |    |    |    | 0  |    |    |    |    |                |    | EVDSTAT |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |                |    |         |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 <sup>1</sup> | 0  | 0       |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2              | 1  | 0       |
| R     |    |    |    |    | 0  |    |    |    |    |    |    |    | 0  |                |    | EVDISO  |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |                |    |         |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0              | 0  | 0       |

1. The reset value of this field can change based on external voltage conditions.

**Fields**

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                 |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-19<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                 |
| 18-16<br>EVDSTAT | External Voltage Domain Status<br>Indicates the status of the external voltage domains.<br>See <a href="#">Table 157</a> for the mapping of each bit of this field. Each bit's value has the following meaning:<br>0b - Isolated or not powered<br>1b - Not isolated                                                                                                     |
| 15-11<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                 |
| 10-8<br>EVDPISO  | External Voltage Domain Low-Power Isolation<br>Isolates the external voltage domain in low-power modes.<br>Use this field if you use the SPC_LPREQ pin to power off any voltage domain in low-power modes.<br>See <a href="#">Table 157</a> for the mapping of each bit of this field. Each bit's value has the following meaning:<br>0b - Not isolated<br>1b - Isolated |
| 7-3<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                 |
| 2-0<br>EVDISO    | External Voltage Domain Isolation<br>Isolates the external voltage domain.<br>Use this field if any voltage domain is always powered off on the board, or whenever a voltage domain is powered off under software control.                                                                                                                                               |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                   |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | See <a href="#">Table 157</a> for the mapping of each bit of this field. Each bit's value has the following meaning:<br>0b - Not isolated<br>1b - Isolated |

## 25.7.20 LDO\_CORE Configuration (CORELDO\_CFG)

### Offset

| Register    | Offset |
|-------------|--------|
| CORELDO_CFG | 300h   |

### Function

Configures LDO\_CORE.

### Diagram

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

### Fields

| Field | Function |
|-------|----------|
| 31-29 | Reserved |
| —     |          |
| 28-24 | Reserved |
| —     |          |
| 23-21 | Reserved |
| —     |          |
| 20-17 | Reserved |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function |
|-------|----------|
| —     |          |
| 16    | Reserved |
| —     |          |
| 15-9  | Reserved |
| —     |          |
| 8     | Reserved |
| —     |          |
| 7-4   | Reserved |
| —     |          |
| 3     | Reserved |
| —     |          |
| 2     | Reserved |
| —     |          |
| 1     | Reserved |
| —     |          |
| 0     | Reserved |
| —     |          |

# Chapter 26

## Standard Counter or Timer (CTIMER)

### 26.1 Chip-specific CTIMER information

Table 158. Reference links to related information

| Topic                | Related module | Reference                                     |
|----------------------|----------------|-----------------------------------------------|
| Full description     | CTIMER         | <a href="#">CTIMER</a>                        |
| System memory map    |                | <a href="#">Memory map</a>                    |
| Clocking             |                | <a href="#">Clock distribution</a>            |
| Power Management     |                | <a href="#">Power Management</a>              |
| Signal multiplexing  | Port control   | <a href="#">Signal multiplexing</a>           |
| Peripheral Input Mux | INPUTMUX       | <a href="#">Peripheral Input multiplexing</a> |

#### 26.1.1 Module instances

This device has three instances of the CTIMER module, CTIMER0, CTIMER1, and CTIMER2. Each timer has up to 4x capture and 4x match registers with corresponding inputs and outputs.

CTimer supports async function clock. The async function clock speed can be higher than APB bus clock.

#### 26.1.2 Signals

The tables below give a summary of each of the Timer/Counter related pins and the recommended PORT settings. Also note that different part number and package variations may provide different CTIMER related pin functions.

Table 159. Timer/Counter pin description

| Pin                                                | Type   | Description                                                                                                                                                                                                                                                                                                                                                                              |
|----------------------------------------------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CTIMER0_CAP3:0<br>CTIMER1_CAP3:0<br>CTIMER2_CAP3:0 | Input  | Capture Signals- A transition on a capture pin can be configured to load one of the Capture Registers with the value in the Timer Counter and optionally generate an interrupt. Capture functionality can be selected from a number of pins.<br><br>Timer/Counter block can select a capture signal as a clock source instead of the APB bus clock. For more details, see CTCR register. |
| CT0_MAT3:0<br>CT1_MAT3:0<br>CT2_MAT3:0             | Output | External Match Output - When a match register (MR3:0) equals the timer counter (TC) this output can either toggle, go low, go high, or do nothing. The External Match Register (EMR) controls the functionality of this output. Match Output functionality can be selected on a number of pins in parallel.                                                                              |

#### 26.1.3 External global enable

When the timer is enabled by the CTIMER global start register in SYSCON, ([CTIMER Global Start Enable \(CTIMERGLOBALSTARTEN\)](#)), it is equivalent to writing 1 to the TCR[CEN] bit in CTIMER. The external global start register is used to enable multiple timers at the same time. This operation is allowed by writing a 1 to each Timer's TCR[AGCEN] bit. If the

Timer control register's CEN bit is already 1, the external global start enable register has no effect (See [CTIMER Global Start Enable \(CTIMERGLOBALSTARTEN\)](#)).

#### 26.1.4 Peripheral Input Multiplexers



Figure 79. Peripheral Input Multiplexers for CTimers

#### 26.1.5 Initialization

1. Select a clock source for the CTIMER using MRCC\_CTIMER0\_CLKSEL, MRCC\_CTIMER1\_CLKSEL, and MRCC\_CTIMER2\_CLKSEL registers.
2. Enable the clock to the CTIMER via the CTIMERGLOBALSTARTEN[CTIMER0\_CLK\_EN], CTIMERGLOBALSTARTEN[CTIMER1\_CLK\_EN], and CTIMERGLOBALSTARTEN[CTIMER2\_CLK\_EN] fields. This enables the register interface and the peripheral function clock.
3. Clear the CTIMER peripheral reset using the MRCC\_GLB\_RST0 registers.
4. Each CTIMER provides interrupts to the NVIC. See MCR and CCR registers in the CTIMER register section for match and capture events. For interrupt connections, see the attached NVIC spreadsheet.
5. Select timer pins and pin modes as needed through the relevant PORT registers.
6. The CTIMER DMA request lines are connected to the DMA trigger inputs via the DMAC0\_ITRIG\_INMUX registers (See [Memory map and register definition](#)). Note that timer DMA request outputs are connected to DMA trigger inputs.

## 26.2 Overview

Each CTIMER is designed to count cycles of the CTIMER function clock or an externally supplied clock. A CTIMER can optionally generate an interrupt or perform other actions at specified timer values based on the settings of [Match \(MR0 - MR3\)](#). Each CTIMER also includes capture input pins (see [Capture mode](#)) to capture the timer value when an input signal transitions, optionally generating an interrupt.

In PWM mode, three match registers can be used to provide a single-edge controlled PWM output on the match output pins. One match register is used to control the PWM cycle length. All match registers can optionally be auto-reloaded from a companion shadow register (see [Match Shadow \(MSR0 - MSR3\)](#)) whenever the counter is reset to zero. This feature permits modifying the match values for the next counter cycle without disrupting PWM waveforms during the current cycle. When enabled, match reload occurs whenever the counter is reset, either because of a match event or by writing 1 to [TCR\[CRST\]](#).

### 26.2.1 Block diagram



Figure 80. Block diagram

### 26.2.2 Features

- Contains a 32-bit CTIMER with a programmable 32-bit prescaler (the timers include external capture and match pin connections)
- Contains [Timer Control \(TCR\)](#) and [External trigger enable](#), either of which you can use to enable each timer (you can also use an external global start enable register to globally enable one or more timers)
- Performs counter or timer operations
- Selects the function clocks that may be asynchronous to other system clocks
- Includes up to four 32-bit captures (see [Capture mode](#)) to take a snapshot of the timer value when an input signal transitions (a capture event may also optionally generate an interrupt, and the number of capture inputs available for each timer on a chip may vary)
- Enables you to configure the timer and prescaler to be cleared on a designated capture event (this feature permits easy pulse-width measurement by clearing the timer on the leading edge of an input pulse, capturing the timer value on the trailing edge)
- Includes [Match \(MR0 - MR3\)](#) to allow:
  - Continuous operation with optional interrupt generation after a match occurs

- Optional auto-reload from [Match Shadow \(MSR0 - MSR3\)](#) when the counter is reset
- Stop timer after a match with optional interrupt generation
- Reset timer after a match with optional interrupt generation
- Generates up to four external outputs corresponding to [Match \(MR0 - MR3\)](#), for each timer, with the following capabilities (the number of match outputs available for each timer on a chip may vary):
  - Go low when matched
  - Go high when matched
  - Toggle when matched
  - Do nothing
- Enables you to configure up to four match registers for PWM operation, allowing up to three single-edged controlled PWM outputs (the number of match outputs available for each timer on a chip may vary)
- Uses up to two match registers to generate DMA requests

### 26.3 Functional description

[Figure 81](#) shows a timer configured to reset the count and generate an interrupt after a match. The value of [Prescale \(PR\)](#) is 2 and the value of [Match \(MR0 - MR3\)](#) is 6. At the end of the timer cycle where the match occurs, the timer count is reset and gives a full-length cycle to the match value. The interrupt indicating that a match has occurred is generated in the next clock after the timer reaches the match value.



Figure 81. Timer cycle with PR = 2, MR<sub>x</sub> = 6, and both interrupt and reset enabled after match

[Figure 82](#) shows a timer configured to stop and generate an interrupt after a match. The value of [Prescale \(PR\)](#) is 2 and the value of [Match \(MR0 - MR3\)](#) is 6. In the next clock after the timer reaches the match value, [TCR\[CEN\]](#) becomes 0 and the interrupt indicating that a match has occurred is generated.



Figure 82. Timer cycle with PR = 2, MR<sub>x</sub> = 6, and both interrupt and stop enabled after match

### 26.3.1 Operation sections

All single-edge controlled PWM outputs go low at the beginning of each PWM cycle (timer is set to zero) unless their match value is zero.

Each PWM output goes high when its match value is reached. If no match occurs (that is, the match value is greater than the PWM cycle length), the PWM output remains continuously low.

If a match value larger than the PWM cycle length is written to [Match \(MR0 - MR3\)](#), and the PWM signal is already high, the PWM signal is cleared at the start of the next PWM cycle.

If a match register contains the same value as the timer reset value (the PWM cycle length), the PWM output is reset to low on the next clock tick after the timer reaches the match value. Therefore, the PWM output always consists of one clock tick wide positive pulse with a period that the PWM cycle length determines (that is, the timer reload value).

If [Match \(MR0 - MR3\)](#) = 0, the PWM output goes to high the first time the timer goes back to zero, and remains high continuously.

The following figure shows sample PWM waveforms with a PWM cycle length of 100 that MR3 specifies and PWM outputs that [PWM Control \(PWMC\)](#) enables.

#### NOTE

When you select match outputs to perform as PWM outputs, you must write 0 to MCR[MRnR] and MCR[MRnS], except to the match register setting the PWM cycle length. For this register, write 1 to MCR[MRnR] to enable the timer reset when the timer value matches the value of the corresponding match register.



Figure 83. Sample PWM waveforms with a PWM cycle length of 100 (selected by MR3) and MAT3:0 enabled as PWM outputs by the PWM Control register.

### 26.3.2 Mode sections

#### 26.3.2.1 Capture mode

You can configure a CAP to load [Capture \(CR0 - CR3\)](#) with the value in the counter or timer and optionally generate an interrupt. One of the pins generates the capture signal with a capture function. Each CAP is connected to one capture channel of the timer.

CTIMER can select a CAP as a clock source instead of selecting the APB CTIMER function clock. See [Count Control \(CTCR\)](#) for more information.

#### 26.3.2.2 Match mode

When the value of a match register ([Match \(MR0 - MR3\)](#)) equals that of [Timer Counter \(TC\)](#), the corresponding match output can either toggle, go low, go high, or do nothing. [External Match \(EMR\)](#) and [PWM Control \(PWMC\)](#) control the functionality of this output.

#### 26.3.3 External trigger enable

When trigger\_enable is asserted (rising edge), it is equivalent to writing 1 to [TCR\[CEN\]](#). If TCR[CEN] is already 1, trigger\_enable rising edge events have no effect.

### 26.3.4 Clocking

Table 160. CTIMER clocks

| Type of clock           | Description                                                                             |
|-------------------------|-----------------------------------------------------------------------------------------|
| Functional Clock(ctclk) | Asynchronous to the bus clock, provide clock to perform counter or timer operations.    |
| Bus Clock(pclk)         | The bus clock is only used for bus accesses to the control and configuration registers. |

### 26.3.5 Reset

[TCR\[CRST\]](#) resets [Timer Counter \(TC\)](#) and [Prescale Counter \(PC\)](#).

### 26.3.6 Interrupts

This module has capture and match interrupts. See the [Interrupt \(IR\)](#)

### 26.3.7 DMA

DMA requests are generated when the value of [Timer Counter \(TC\)](#) either matches the value of MR0 or MR1 (see [Match \(MR0 - MR3\)](#) for more information). This DMA request is not connected to the operation of the match outputs (see [Match mode](#)) controlled by [External Match \(EMR\)](#). Each match sets a DMA request flag, which is connected to the DMA controller. You must configure the DMA controller correctly.

When a timer is initially set up to generate a DMA request, the request may already be asserted before a match condition occurs. An initial DMA request may be avoided by writing 1 to the interrupt flag location, as if clearing a timer interrupt. See [Interrupt \(IR\)](#) for more information. A DMA request is cleared automatically when the DMA controller manages it.

**NOTE**

Timer DMA requests are generated whenever the timer value is equal to the related match register value. DMA requests are always generated when the timer is running, unless the match register value is higher than the upper count limit of the timer. It is important not to select and enable timer DMA requests in the DMA block unless you configure the timer correctly to generate valid DMA requests.

## 26.4 External signals

Table 161. CTIMER pin descriptions

| Pin                 | Type   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CTIMER $m$ _CAP $n$ | Input  | Capture signals—You can configure a transition on a capture pin to load one of the capture registers ( <a href="#">Capture (CR0 - CR3)</a> ) with the value of <a href="#">Timer Counter (TC)</a> and optionally generate an interrupt. You can select the capture functionality for a number of pins.<br><br>CTIMER can select a capture signal as a clock source instead of the APB bus clock. See <a href="#">Count Control (CTCR)</a> for more information. |
| CTIMER $m$ _MAT $n$ | Output | External match output—When the value of a match register ( <a href="#">Match (MR0 - MR3)</a> ) equals the value of <a href="#">Timer Counter (TC)</a> , this output can either toggle, go low, go high, or do nothing. <a href="#">External Match (EMR)</a> controls the functionality of this output. You can select the match output functionality for a number of pins in parallel.                                                                          |

### 26.4.1 Multiple capture (CAP) and match (MAT) pins

You can configure the pins of the chip to be used for this module. These pins are generally reused, and you can connect several internal module pins selectively. However, you can connect only one internal pin at a time.

**NOTE**

Match conditions may be used internally without the use of a chip's pin.

## 26.5 Initialization

See the Chip-specific CTIMER information for the initialization section for more details or steps.

## 26.6 Application information

[CTIMER register descriptions](#) discusses the following:

- Interval timer for counting internal events
- PWM outputs
- Pulse width demodulator via capture inputs
- Free running timer

## 26.7 CTIMER register descriptions

### 26.7.1 CTIMER memory map

CTIMER0 base address: 4000\_4000h

CTIMER1 base address: 4000\_5000h

CTIMER2 base address: 4000\_6000h

| Offset    | Register                                   | Width<br>(In bits) | Access | Reset value                 |
|-----------|--------------------------------------------|--------------------|--------|-----------------------------|
| 0h        | <a href="#">Interrupt (IR)</a>             | 32                 | RW     | <a href="#">See section</a> |
| 4h        | <a href="#">Timer Control (TCR)</a>        | 32                 | RW     | <a href="#">See section</a> |
| 8h        | <a href="#">Timer Counter (TC)</a>         | 32                 | RW     | 0000_0000h                  |
| Ch        | <a href="#">Prescale (PR)</a>              | 32                 | RW     | 0000_0000h                  |
| 10h       | <a href="#">Prescale Counter (PC)</a>      | 32                 | RW     | 0000_0000h                  |
| 14h       | <a href="#">Match Control (MCR)</a>        | 32                 | RW     | <a href="#">See section</a> |
| 18h - 24h | <a href="#">Match (MR0 - MR3)</a>          | 32                 | RW     | 0000_0000h                  |
| 28h       | <a href="#">Capture Control (CCR)</a>      | 32                 | RW     | <a href="#">See section</a> |
| 2Ch - 38h | <a href="#">Capture (CR0 - CR3)</a>        | 32                 | R      | 0000_0000h                  |
| 3Ch       | <a href="#">External Match (EMR)</a>       | 32                 | RW     | <a href="#">See section</a> |
| 70h       | <a href="#">Count Control (CTCR)</a>       | 32                 | RW     | <a href="#">See section</a> |
| 74h       | <a href="#">PWM Control (PWMC)</a>         | 32                 | RW     | <a href="#">See section</a> |
| 78h - 84h | <a href="#">Match Shadow (MSR0 - MSR3)</a> | 32                 | RW     | 0000_0000h                  |

## 26.7.2 Interrupt (IR)

### Offset

| Register | Offset |
|----------|--------|
| IR       | 0h     |

### Function

Provides flags for match interrupts and capture interrupts. If an interrupt is generated, it sets the corresponding flag in this register. Otherwise, the flag remains cleared. Writing 1 to the corresponding IR field resets the interrupt. Writing 0 has no effect. Clearing an interrupt for a timer match also clears any corresponding DMA request. You can write to this register to clear interrupts, and can read this register to identify which interrupt sources are pending.

### Diagram

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23         | 22         | 21         | 20         | 19         | 18         | 17         | 16         |
|-------|----|----|----|----|----|----|----|----|------------|------------|------------|------------|------------|------------|------------|------------|
| R     |    |    |    |    |    |    |    |    |            |            |            |            |            |            |            |            |
| W     |    |    |    |    |    |    |    |    |            |            |            |            |            |            |            |            |
| Reset | u  | u  | u  | u  | u  | u  | u  | u  | u          | u          | u          | u          | u          | u          | u          | u          |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0          |
| R     |    |    |    |    |    |    |    |    | CR3IN<br>T | CR2IN<br>T | CR1IN<br>T | CROIN<br>T | MR3IN<br>T | MR2IN<br>T | MR1IN<br>T | MR0IN<br>T |
| W     |    |    |    |    |    |    |    |    | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          |
| Reset | u  | u  | u  | u  | u  | u  | u  | u  |            |            |            |            |            |            |            |            |

### Fields

| Field         | Function                                                                                                             |
|---------------|----------------------------------------------------------------------------------------------------------------------|
| 31-8<br>—     | Reserved                                                                                                             |
| 7-4<br>CRnINT | Interrupt Flag for Capture Channel <i>n</i> Event<br>Controls an interrupt flag for capture channel <i>n</i> events. |
| 3-0<br>MRnINT | Interrupt Flag for Match Channel <i>n</i> Event<br>Controls an interrupt flag for match channel <i>n</i> events.     |

## 26.7.3 Timer Control (TCR)

### Offset

| Register | Offset |
|----------|--------|
| TCR      | 4h     |

**Function**

Controls timer counter functions. You can disable or reset [Timer Counter \(TC\)](#) by using this register.

**Diagram**

|       |          |    |    |    |    |    |    |    |    |    |           |           |          |      |     |    |
|-------|----------|----|----|----|----|----|----|----|----|----|-----------|-----------|----------|------|-----|----|
| Bits  | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21        | 20        | 19       | 18   | 17  | 16 |
| R     | Reserved |    |    |    |    |    |    |    |    |    |           |           |          |      |     |    |
| W     |          |    |    |    |    |    |    |    |    |    |           |           |          |      |     |    |
| Reset | u        | u  | u  | u  | u  | u  | u  | u  | u  | u  | u         | u         | u        | u    | u   | u  |
| Bits  | 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5         | 4         | 3        | 2    | 1   | 0  |
| R     | Reserved |    |    |    |    |    |    |    |    |    | ATCE<br>N | AGCE<br>N | Reserved | CRST | CEN |    |
| W     |          |    |    |    |    |    |    |    |    |    | 0         | 0         | u        | u    | 0   | 0  |
| Reset | u        | u  | u  | u  | u  | u  | u  | u  | u  | u  | 0         | 0         | u        | u    | 0   | 0  |

**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                               |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                               |
| 5<br>ATCEN | <p>Allow Trigger Count Enable</p> <p>Enables the input trigger. If this field is 1, it allows the input trigger_enable = 1 action to take effect (see <a href="#">External trigger enable</a>). If this field is 0, the action is not allowed.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                 |
| 4<br>AGCEN | <p>Allow Global Count Enable</p> <p>Enables the global count. If this field is 1, it allows the input global_enable = 1 action to take effect. If this field = 0, the action is not allowed.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                   |
| 3-2<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                               |
| 1<br>CRST  | <p>Counter Reset Enable</p> <p>Enables the counter reset. If this field is 1, <a href="#">Timer Counter (TC)</a> and <a href="#">Prescale Counter (PC)</a> are synchronously reset after the next positive edge of the CTIMER function clock. The counters remain reset until this field becomes 0. If this field is 0, no effect takes place.</p> <p>0b - Disable<br/>1b - Enable</p> |
| 0          | Counter Enable                                                                                                                                                                                                                                                                                                                                                                         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                          |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CEN   | Enables the counters. If this field is 1, <a href="#">Timer Counter (TC)</a> and <a href="#">Prescale Counter (PC)</a> are enabled.<br>When an external trigger enables the timer or the external global start enable register enables it, this field becomes 1 automatically.<br><br>0b - Disable<br>1b - Enable |

## 26.7.4 Timer Counter (TC)

### Offset

| Register | Offset |
|----------|--------|
| TC       | 8h     |

### Function

Specifies the timer counter.

This register is incremented when [Prescale Counter \(PC\)](#) reaches its terminal count. Unless it is reset before reaching its upper limit, [Timer Counter \(TC\)](#) counts up through the value FFFF\_FFFFh, and then wraps back to the value 0000\_0000h. This event does not cause an interrupt, but you can use [Match \(MR0 - MR3\)](#) to detect an overflow if needed.

[Timer Counter \(TC\)](#) is incremented after every [Prescale \(PR\)](#) + 1 cycle of the CTIMER function clock. [Timer Control \(TCR\)](#) controls the functioning of this register.

### Diagram



### Fields

| Field | Function                                  |
|-------|-------------------------------------------|
| 31-0  | Timer Counter Value                       |
| TCVAL | Specifies the value of the timer counter. |

### 26.7.5 Prescale (PR)

#### Offset

| Register | Offset |
|----------|--------|
| PR       | Ch     |

#### Function

Specifies the prescale value.

If [Prescale Counter \(PC\)](#) is equal to the prescale value, the next clock timer increments [Timer Counter \(TC\)](#) and turns the value of [Prescale Counter \(PC\)](#) to 0.

#### Diagram

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

#### Fields

| Field | Function                                    |
|-------|---------------------------------------------|
| 31-0  | Prescale Reload Value                       |
| PRVAL | Specifies the value of the prescale reload. |

### 26.7.6 Prescale Counter (PC)

#### Offset

| Register | Offset |
|----------|--------|
| PC       | 10h    |

#### Function

Controls the division of the CTIMER function clock by some constant value before it is applied to [Timer Counter \(TC\)](#). This allows control of the relationship between the resolution of the timer and the maximum time before the timer overflows.

[Prescale Counter \(PC\)](#) is incremented on every CTIMER function clock. When it reaches the value stored in [Prescale \(PR\)](#), [Timer Counter \(TC\)](#) is incremented and [Prescale Counter \(PC\)](#) is reset on the next CTIMER function clock. This causes [Timer Counter \(TC\)](#) to increment on every CTIMER function clock when [Prescale \(PR\)](#) = 0, every two CTIMER function clocks when [Prescale \(PR\)](#) = 1, and so on.

You can use the bus interface to observe and control [Prescale Counter \(PC\)](#).

#### Diagram

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

#### Fields

| Field | Function                                     |
|-------|----------------------------------------------|
| 31-0  | Prescale Counter Value                       |
| PCVAL | Specifies the value of the prescale counter. |

## 26.7.7 Match Control (MCR)

#### Offset

| Register | Offset |
|----------|--------|
| MCR      | 14h    |

#### Function

Controls the operations that are performed when one of the match registers ([Match \(MR0 - MR3\)](#)) matches [Timer Counter \(TC\)](#).

#### Diagram

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

## Fields

| Field          | Function                                                                                                                                                                                                                                                                                                         |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-28<br>—     | Reserved                                                                                                                                                                                                                                                                                                         |
| 27-24<br>MRnRL | <p>Reload MR</p> <p>Reloads with the contents of the match n shadow register (see <a href="#">Match Shadow (MSR0 - MSR3)</a>) when <a href="#">Timer Counter (TC)</a> is reset to zero (either via a match event or by writing 1 to <a href="#">TCR[CRST]</a>).</p> <p>0b - Does not reload<br/>1b - Reloads</p> |
| 23-12<br>—     | Reserved                                                                                                                                                                                                                                                                                                         |
| 11<br>MR3S     | <p>Stop on MR3</p> <p>Stops <a href="#">Timer Counter (TC)</a> and <a href="#">Prescale Counter (PC)</a>, and turns <a href="#">TCR[CEN]</a> to 0 if MR3 matches <a href="#">Timer Counter (TC)</a>.</p> <p>0b - Does not stop<br/>1b - Stops</p>                                                                |
| 10<br>MR3R     | <p>Reset on MR3</p> <p>Resets <a href="#">Timer Counter (TC)</a> if MR3 matches its value.</p> <p>0b - Does not reset<br/>1b - Resets</p>                                                                                                                                                                        |
| 9<br>MR3I      | <p>Interrupt on MR3</p> <p>Generates an interrupt when MR3 matches the value in <a href="#">Timer Counter (TC)</a>.</p> <p>0b - Does not generate<br/>1b - Generates</p>                                                                                                                                         |
| 8<br>MR2S      | <p>Stop on MR2</p> <p>Stops <a href="#">Timer Counter (TC)</a> and <a href="#">Prescale Counter (PC)</a>, and turns <a href="#">TCR[CEN]</a> to 0 if MR2 matches <a href="#">Timer Counter (TC)</a>.</p> <p>0b - Does not stop<br/>1b - Stops</p>                                                                |
| 7<br>MR2R      | <p>Reset on MR2</p> <p>Resets <a href="#">Timer Counter (TC)</a> if MR2 matches its value.</p> <p>0b - Does not reset<br/>1b - Resets</p>                                                                                                                                                                        |
| 6              | Interrupt on MR2                                                                                                                                                                                                                                                                                                 |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                                                            |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MR2I      | Generates an interrupt when MR2 matches the value in <a href="#">Timer Counter (TC)</a> .<br>0b - Does not generate<br>1b - Generates                                                                                               |
| 5<br>MR1S | Stop on MR1<br>Stops <a href="#">Timer Counter (TC)</a> and <a href="#">Prescale Counter (PC)</a> , and turns <a href="#">TCR[CEN]</a> to 0 if MR1 matches <a href="#">Timer Counter (TC)</a> .<br>0b - Does not stop<br>1b - Stops |
| 4<br>MR1R | Reset on MR1<br>Resets <a href="#">Timer Counter (TC)</a> if MR1 matches its value.<br>0b - Does not reset<br>1b - Resets                                                                                                           |
| 3<br>MR1I | Interrupt on MR1<br>Generates an interrupt when MR1 matches the value in <a href="#">Timer Counter (TC)</a> .<br>0b - Does not generate<br>1b - Generates                                                                           |
| 2<br>MR0S | Stop on MR0<br>Stops <a href="#">Timer Counter (TC)</a> and <a href="#">Prescale Counter (PC)</a> , and turns <a href="#">TCR[CEN]</a> to 0 if MR0 matches <a href="#">Timer Counter (TC)</a> .<br>0b - Does not stop<br>1b - Stops |
| 1<br>MR0R | Reset on MR0<br>Resets <a href="#">Timer Counter (TC)</a> if MR0 matches its value.<br>0b - Does not reset<br>1b - Resets                                                                                                           |
| 0<br>MR0I | Interrupt on MR0<br>Generates an interrupt when MR0 matches the value in <a href="#">Timer Counter (TC)</a> .<br>0b - Does not generate<br>1b - Generates                                                                           |

## 26.7.8 Match (MR0 - MR3)

### Offset

| Register | Offset |
|----------|--------|
| MR0      | 18h    |
| MR1      | 1Ch    |
| MR2      | 20h    |
| MR3      | 24h    |

### Function

Continuously compares the value of **Match (MR0 - MR3)** with the value of **TC[TCVAL]**. When both the values are equal, actions such as the following can be triggered automatically:

- Generation of an interrupt
- Resetting of **Timer Counter (TC)**
- Stopping of the timer

The settings defined in **Match Control (MCR)** control these actions.

If **MCR[MRnRL]** = 1, **Match (MR0 - MR3)** is automatically reloaded with the current contents of its corresponding **Match Shadow (MSR0 - MSR3)** whenever **Timer Counter (TC)** becomes 0. This transfer takes place on the same clock edge that advances **Timer Counter (TC)** to 0.

#### NOTE

**Timer Counter (TC)** resets in response to an occurrence of a match on **MATCH** being used to set the cycle counter rate. A reset can also occur if you write 1 to **TCR[CRST]**.

### Diagram

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

### Fields

| Field | Function                                                                                                |
|-------|---------------------------------------------------------------------------------------------------------|
| 31-0  | Timer Counter Match Value                                                                               |
| MATCH | Triggers an action automatically when the value of this field is the same as that of <b>TC[TCVAL]</b> . |

### 26.7.9 Capture Control (CCR)

#### Offset

| Register | Offset |
|----------|--------|
| CCR      | 28h    |

#### Function

Controls whether one of the capture registers ([Capture \(CR0 - CR3\)](#)) is loaded with the value in [Timer Counter \(TC\)](#) when the capture event occurs. The register also controls whether the capture event generates an interrupt. When you configure both the rising and falling bits at the same time, which is a valid configuration, it results into a capture event for both edges. In the description below, "n" represents the timer number, 0 or 1.

#### NOTE

If you select Counter mode for a particular CAPn input in [Count Control \(CTCR\)](#), you must program the fields in this register as 0. You can select both capture and interrupt for the other CAPn inputs.

#### Diagram

| Bits  | 31 | 30 | 29 | 28 | 27       | 26     | 25     | 24    | 23     | 22     | 21    | 20     | 19     | 18    | 17     | 16     |
|-------|----|----|----|----|----------|--------|--------|-------|--------|--------|-------|--------|--------|-------|--------|--------|
| R     |    |    |    |    |          |        |        |       |        |        |       |        |        |       |        |        |
| W     |    |    |    |    |          |        |        |       |        |        |       |        |        |       |        |        |
| Reset | u  | u  | u  | u  | u        | u      | u      | u     | u      | u      | u     | u      | u      | u     | u      | u      |
| Bits  | 15 | 14 | 13 | 12 | 11       | 10     | 9      | 8     | 7      | 6      | 5     | 4      | 3      | 2     | 1      | 0      |
| R     |    |    |    |    | CAP3I    | CAP3FE | CAP3RE | CAP2I | CAP2FE | CAP2RE | CAP1I | CAP1FE | CAP1RE | CAP0I | CAP0FE | CAP0RE |
| W     |    |    |    |    | Reserved |        |        |       | 0      | 0      | 0     | 0      | 0      | 0     | 0      | 0      |
| Reset | u  | u  | u  | u  | 0        | 0      | 0      | 0     | 0      | 0      | 0     | 0      | 0      | 0     | 0      | 0      |

#### Fields

| Field        | Function                                                                                                                                                         |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-12<br>—   | Reserved                                                                                                                                                         |
| 11<br>CAP3I  | Generate Interrupt on Channel 3 Capture Event<br>Generates an interrupt on channel 3 capture event using a CR3 load.<br>0b - Does not generate<br>1b - Generates |
| 10<br>CAP3FE | Falling Edge of Capture Channel 3<br>Loads CR3 with the contents of <a href="#">Timer Counter (TC)</a> when you write 1 and then 0 to this field.                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                              |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 0b - Does not load<br>1b - Loads                                                                                                                                                      |
| 9<br>CAP3RE | Rising Edge of Capture Channel 3<br>Loads CR3 with the contents of <a href="#">Timer Counter (TC)</a> when you write 0 and then 1 to this field.<br>0b - Does not load<br>1b - Loads  |
| 8<br>CAP2I  | Generate Interrupt on Channel 2 Capture Event<br>Generates an interrupt on channel 2 capture event using a CR2 load.<br>0b - Does not generate<br>1b - Generates                      |
| 7<br>CAP2FE | Falling Edge of Capture Channel 2<br>Loads CR2 with the contents of <a href="#">Timer Counter (TC)</a> when you write 1 and then 0 to this field.<br>0b - Does not load<br>1b - Loads |
| 6<br>CAP2RE | Rising Edge of Capture Channel 2<br>Loads CR2 with the contents of <a href="#">Timer Counter (TC)</a> when you write 0 and then 1 to this field.<br>0b - Does not load<br>1b - Loads  |
| 5<br>CAP1I  | Generate Interrupt on Channel 1 Capture Event<br>Generates an interrupt on channel 1 capture event using a CR1 load.<br>0b - Does not generates<br>1b - Generates                     |
| 4<br>CAP1FE | Falling Edge of Capture Channel 1<br>Loads CR1 with the contents of <a href="#">Timer Counter (TC)</a> when you write 1 and then 0 to this field.<br>0b - Does not load<br>1b - Loads |
| 3<br>CAP1RE | Rising Edge of Capture Channel 1<br>Loads CR1 with the contents of <a href="#">Timer Counter (TC)</a> when you write 0 and then 1 to this field.<br>0b - Does not load<br>1b - Loads  |
| 2           | Generate Interrupt on Channel 0 Capture Event                                                                                                                                         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                              |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CAP0I       | Generates an interrupt on channel 0 capture event using a CR0 load.<br>0b - Does not generate<br>1b - Generates                                                                       |
| 1<br>CAP0FE | Falling Edge of Capture Channel 0<br>Loads CR0 with the contents of <a href="#">Timer Counter (TC)</a> when you write 1 and then 0 to this field.<br>0b - Does not load<br>1b - Loads |
| 0<br>CAP0RE | Rising Edge of Capture Channel 0<br>Loads CR0 with the contents of <a href="#">Timer Counter (TC)</a> when you write 0 and then 1 to this field.<br>0b - Does not load<br>1b - Loads  |

## 26.7.10 Capture (CR0 - CR3)

### Offset

| Register | Offset |
|----------|--------|
| CR0      | 2Ch    |
| CR1      | 30h    |
| CR2      | 34h    |
| CR3      | 38h    |

### Function

Works with a capture channel and may load with the value of [Timer Counter \(TC\)](#) when a specified event occurs on the signal defined for that capture channel. The signal could originate from an external pin or an internal source.

This register determines whether the capture function is enabled, and whether a capture event happens on the rising edge, falling edge, or on both edges of the associated signal. The register is loaded with the value of [Timer Counter \(TC\)](#) when there is an event on the CAP $n$  input.

**Diagram**

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

**Fields**

| Field | Function                                                                                                      |
|-------|---------------------------------------------------------------------------------------------------------------|
| 31-0  | Timer Counter Capture Value                                                                                   |
| CAP   | Determines whether the capture function is enabled and defines the edge on which the capture function occurs. |

**26.7.11 External Match (EMR)****Offset**

| Register | Offset |
|----------|--------|
| EMR      | 3Ch    |

**Function**

Provides both control and status of the external match pins. If the match outputs (see [Match mode](#)) are configured as PWM outputs, PWM rules determine the function of this register.

**Diagram**

| Bits  | 31       | 30 | 29 | 28 | 27   | 26 | 25   | 24 | 23   | 22 | 21   | 20 | 19  | 18  | 17  | 16  |
|-------|----------|----|----|----|------|----|------|----|------|----|------|----|-----|-----|-----|-----|
| R     | Reserved |    |    |    |      |    |      |    |      |    |      |    |     |     |     |     |
| W     |          |    |    |    |      |    |      |    |      |    |      |    |     |     |     |     |
| Reset | u        | u  | u  | u  | u    | u  | u    | u  | u    | u  | u    | u  | u   | u   | u   | u   |
| Bits  | 15       | 14 | 13 | 12 | 11   | 10 | 9    | 8  | 7    | 6  | 5    | 4  | 3   | 2   | 1   | 0   |
| R     | Reserved |    |    |    | EMC3 |    | EMC2 |    | EMC1 |    | EMC0 |    | EM3 | EM2 | EM1 | EM0 |
| W     |          |    |    |    |      |    |      |    |      |    |      |    | 0   | 0   | 0   | 0   |
| Reset | u        | u  | u  | u  | 0    | 0  | 0    | 0  | 0    | 0  | 0    | 0  | 0   | 0   | 0   | 0   |

**Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-12<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 11-10<br>EMC3 | <p>External Match Control 3</p> <p>Determines the functionality of <a href="#">EM3</a>:</p> <ul style="list-style-type: none"> <li>• If this field is 1, the corresponding external match field or output becomes 0 (if pinned out MAT3 pin is low).</li> <li>• If this field is 10, the corresponding external match field or output becomes 1 (if pinned out MAT3 pin is high).</li> <li>• If this field is 11, it toggles the corresponding external match field or output.</li> </ul> <p>00b - Does nothing<br/>01b - Goes low<br/>10b - Goes high<br/>11b - Toggles</p> |
| 9-8<br>EMC2   | <p>External Match Control 2</p> <p>Determines the functionality of <a href="#">EM2</a>:</p> <ul style="list-style-type: none"> <li>• If this field is 1, the corresponding external match field or output becomes 0 (if pinned out MAT2 pin is low).</li> <li>• If this field is 10, the corresponding external match field or output becomes 1 (if pinned out MAT2 pin is high).</li> <li>• If this field is 11, it toggles the corresponding external match field or output.</li> </ul> <p>00b - Does nothing<br/>01b - Goes low<br/>10b - Goes high<br/>11b - Toggles</p> |
| 7-6<br>EMC1   | <p>External Match Control 1</p> <p>Determines the functionality of <a href="#">EM1</a>:</p> <ul style="list-style-type: none"> <li>• If this field is 1, the corresponding external match field or output becomes 0 (if pinned out MAT1 pin is low).</li> <li>• If this field is 10, the corresponding external match field or output becomes 1 (if pinned out MAT1 pin is high).</li> <li>• If this field is 11, it toggles the corresponding external match field or output.</li> </ul> <p>00b - Does nothing<br/>01b - Goes low<br/>10b - Goes high</p>                   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 11b - Toggles                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 5-4<br>EMC0 | <p>External Match Control 0</p> <p>Determines the functionality of <a href="#">EM0</a>:</p> <ul style="list-style-type: none"> <li>If this field is 1, the corresponding external match field or output becomes 0 (if pinned out MAT0 pin is low).</li> <li>If this field is 10, the corresponding external match field or output becomes 1 (if pinned out MAT0 pin is high).</li> <li>If this field is 11, it toggles the corresponding external match field or output.</li> </ul> <p>00b - Does nothing</p> <p>01b - Goes low</p> <p>10b - Goes high</p> <p>11b - Toggles</p> |
| 3<br>EM3    | <p>External Match 3</p> <p>Reflects the state of output MAT3—whether this output is connected to a pin. If a match occurs between <a href="#">Timer Counter (TC)</a> and MR3 (see <a href="#">Match (MR0 - MR3)</a>), this field can either toggle, go low, go high, or do nothing, as selected by <a href="#">EMC3</a>. This field is driven to the MAT pins if the match function is selected via IOPCTL.</p> <p>0b - Low</p> <p>1b - High</p>                                                                                                                                |
| 2<br>EM2    | <p>External Match 2</p> <p>Reflects the state of output MAT2—whether this output is connected to a pin. If a match occurs between <a href="#">Timer Counter (TC)</a> and MR2 (see <a href="#">Match (MR0 - MR3)</a>), this field can either toggle, go low, go high, or do nothing, as selected by <a href="#">EMC2</a>. This field is driven to the MAT pins if the match function is selected via IOPCTL.</p> <p>0b - Low</p> <p>1b - High</p>                                                                                                                                |
| 1<br>EM1    | <p>External Match 1</p> <p>Reflects the state of output MAT1—whether this output is connected to a pin. If a match occurs between <a href="#">Timer Counter (TC)</a> and MR1 (see <a href="#">Match (MR0 - MR3)</a>), this field can either toggle, go low, go high, or do nothing, as selected by <a href="#">EMC1</a>. This field is driven to the MAT pins if the match function is selected via IOPCTL.</p> <p>0b - Low</p> <p>1b - High</p>                                                                                                                                |
| 0<br>EM0    | <p>External Match 0</p> <p>Reflects the state of output MAT0—whether this output is connected to a pin. If a match occurs between <a href="#">Timer Counter (TC)</a> and MR0 (see <a href="#">Match (MR0 - MR3)</a>), this field can either toggle, go low, go high, or</p>                                                                                                                                                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                      |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | do nothing, as selected by <a href="#">EMC0</a> . This field is driven to the MAT pins if the match function is selected via IOPCTL.<br>0b - Low<br>1b - High |

## 26.7.12 Count Control (CTCR)

### Offset

| Register | Offset |
|----------|--------|
| CTCR     | 70h    |

### Function

Selects between Timer and Counter mode, and in Counter mode, selects the signal and edges for counting.

When Counter mode is selected as the mode of operation, the CAP input (selected by [CINSEL](#)) is sampled on every rising edge of the CTIMER function clock. After comparing two consecutive samples of this CAP input, one of the following four events is recognized:

- Rising edge
- Falling edge
- Either of the edges
- No change in the selected CAP input level

Only if the identified event occurs and the event corresponds to the one selected by [CTMODE](#), [Timer Counter \(TC\)](#) is incremented.

Effective processing of the externally supplied clock to the counter has some limitations:

- Because two successive rising edges of the CTIMER function clock are used to identify only one edge on the CAP selected input, the frequency of the CAP input cannot exceed one half of the CTIMER function clock.
- Consequently, the duration of the high or low levels on the same CAP input in this case cannot be shorter than the CTIMER function clock duration.

You can also use [ENCC](#) and [SELCC](#) to enable and configure the capture-clears-timer feature. This feature allows for a designated edge on a particular CAP input to reset the timer to all zeros. Using this mechanism to clear the timer on the leading edge of an input pulse and perform a capture on the trailing edge permits direct pulse-width measurement using a single capture input without the need to perform a subtraction operation in software.

**Diagram**

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

**Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| —             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7-5<br>SELCC  | <p>Edge Select</p> <p>Selects which input edge (rising or falling) causes the timer and prescaler to be cleared, when ENCC is 1. These fields have no effect when ENCC is 0. The values 6h–7h are reserved.</p> <ul style="list-style-type: none"> <li>000b - Capture channel 0 rising edge</li> <li>001b - Capture channel 0 falling edge</li> <li>010b - Capture channel 1 rising edge</li> <li>011b - Capture channel 1 falling edge</li> <li>100b - Capture channel 2 rising edge</li> <li>101b - Capture channel 2 falling edge</li> </ul>                                                                                                |
| 4<br>ENCC     | <p>Capture Channel Enable</p> <p>Enables capture channel. Writing 1 to this field enables clearing of the timer and the prescaler when the capture-edge event specified in SELCC occurs.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3-2<br>CINSEL | <p>Count Input Select</p> <p>Selects which CAP pin is sampled for clocking when CTMODE is not 0.</p> <p><b>NOTE</b></p> <p>If Counter mode is selected for a particular CAPn input in Count Control (CTCR), you must program the corresponding fields for that input in Capture Control (CCR) as 0. However, you can select both capture and interrupt for the other three CAPn inputs in the same timer.</p> <ul style="list-style-type: none"> <li>00b - Channel 0, CAPn[0] for CTIMERn</li> <li>01b - Channel 1, CAPn[1] for CTIMERn</li> <li>10b - Channel 2, CAPn[2] for CTIMERn</li> <li>11b - Channel 3, CAPn[3] for CTIMERn</li> </ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1-0<br>CTMODE | <p>Counter Timer Mode</p> <p>Selects between Timer and Counter mode, and in Counter mode, selects the signal and edges for counting:</p> <ul style="list-style-type: none"> <li>If this field is 0, every rising CTIMER function clock edge is incremented.</li> <li>If this field is 1, <a href="#">Timer Counter (TC)</a> is incremented on the rising edges of the CAP input selected by <a href="#">CINSEL</a>.</li> <li>If this field is 10, <a href="#">Timer Counter (TC)</a> is incremented on the falling edges of the CAP input selected by <a href="#">CINSEL</a>.</li> <li>If this field is 11, <a href="#">Timer Counter (TC)</a> is incremented on both edges of the CAP input selected by <a href="#">CINSEL</a>.</li> </ul> <p>00b - Timer mode</p> <p>01b - Counter mode rising edge</p> <p>10b - Counter mode falling edge</p> <p>11b - Counter mode dual edge</p> |

### 26.7.13 PWM Control (PWMC)

#### Offset

| Register | Offset |
|----------|--------|
| PWMC     | 74h    |

#### Function

Configures match outputs (see [Match mode](#)) as PWM outputs. You can independently set each match output to perform either as a PWM output or match output controlled by [External Match \(EMR\)](#).

#### NOTE

Different part numbers and package variations may provide different match output pin functions.

For each timer, you can select a maximum of three single-edge controlled PWM outputs on the MAT $n$ [2:0] outputs. One additional match register (see [Match \(MR0 - MR3\)](#)) determines the PWM cycle length. When a match occurs in any of the other match registers, the PWM output is set to high. The match register resets the timer that you can configure to set the PWM cycle length. When the timer is reset to zero, all currently high match outputs configured as PWM outputs are cleared.

This register enables PWM mode for the external match pins.

**Diagram**

|       |          |    |    |    |    |    |    |    |    |    |    |    |         |         |         |         |
|-------|----------|----|----|----|----|----|----|----|----|----|----|----|---------|---------|---------|---------|
| Bits  | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19      | 18      | 17      | 16      |
| R     | Reserved |    |    |    |    |    |    |    |    |    |    |    |         |         |         |         |
| W     |          |    |    |    |    |    |    |    |    |    |    |    |         |         |         |         |
| Reset | u        | u  | u  | u  | u  | u  | u  | u  | u  | u  | u  | u  | u       | u       | u       |         |
| Bits  | 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3       | 2       | 1       | 0       |
| R     | Reserved |    |    |    |    |    |    |    |    |    |    |    |         |         |         |         |
| W     |          |    |    |    |    |    |    |    |    |    |    |    | PWME N3 | PWME N2 | PWME N1 | PWME N0 |
| Reset | u        | u  | u  | u  | u  | u  | u  | u  | u  | u  | u  | u  | 0       | 0       | 0       | 0       |

**Fields**

| Field       | Function                                                                                                                                                                                                                                                                                                        |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4        | Reserved                                                                                                                                                                                                                                                                                                        |
| —           |                                                                                                                                                                                                                                                                                                                 |
| 3<br>PWMEN3 | <p>PWM Mode Enable for Channel 3</p> <p>Enables PWM mode for channel 3. Use match channel 3 to set the PWM cycle length. If this field is 0, <a href="#">EM3</a> controls CTIMER<sub>n</sub>_MAT3. If this field is 1, PWM mode is enabled for CTIMER<sub>n</sub>_MAT3.</p> <p>0b - Disable<br/>1b - Enable</p> |
| 2<br>PWMEN2 | <p>PWM Mode Enable for Channel 2</p> <p>Enables PWM mode for channel 2. If this field is 0, <a href="#">EM2</a> controls CTIMER<sub>n</sub>_MAT2. If this field is 1, PWM mode is enabled for CTIMER<sub>n</sub>_MAT2.</p> <p>0b - Disable<br/>1b - Enable</p>                                                  |
| 1<br>PWMEN1 | <p>PWM Mode Enable for Channel 1</p> <p>Enables PWM mode for channel 1. If this field is 0, <a href="#">EM1</a> controls CTIMER<sub>n</sub>_MAT1. If this field is 1, PWM mode is enabled for CTIMER<sub>n</sub>_MAT1.</p> <p>0b - Disable<br/>1b - Enable</p>                                                  |
| 0<br>PWMEN0 | <p>PWM Mode Enable for Channel 0</p> <p>Enables PWM mode for channel 0. If this field is 0, <a href="#">EM0</a> controls CTIMER<sub>n</sub>_MAT0. If this field is 1, PWM mode is enabled for CTIMER<sub>n</sub>_MAT0.</p> <p>0b - Disable<br/>1b - Enable</p>                                                  |

### 26.7.14 Match Shadow (MSR0 - MSR3)

#### Offset

| Register | Offset |
|----------|--------|
| MSR0     | 78h    |
| MSR1     | 7Ch    |
| MSR2     | 80h    |
| MSR3     | 84h    |

#### Function

Contains the value that the corresponding [Match \(MR0 - MR3\)](#) are (optionally) reloaded with at the start of each new counter cycle. Typically, the match that causes the counter to be reset (and instigates the match reload) is also programmed to generate an interrupt or DMA request. Software or the DMA engine then has one full counter cycle to modify the contents of this register before the next reload occurs.

#### Diagram



#### Fields

| Field            | Function                                                                                                               |
|------------------|------------------------------------------------------------------------------------------------------------------------|
| 31-0             | Timer Counter Match Shadow Value                                                                                       |
| MATCH_SHAD<br>OW | Reloads automatically with the contents of this register whenever <a href="#">Timer Counter (TC)</a> is reset to zero. |

# Chapter 27

## Windowed Watchdog Timer (WWDT)

### 27.1 Chip-specific WWDT information

Table 162. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | WWDT           | <a href="#">WWDT</a>                |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 27.1.1 Module instances

This device has one instance of the WWDT module, WWDT0.

#### 27.1.2 LOCK function

WWDT supports lock function. Once WWDT is locked, WWDT configuration, including clock, can't be changed.

#### 27.1.3 MOD[LOCK] behavior

When MOD[LOCK] is set, the write accesses to SYSCON registers are blocked.

- WWDT0: After LOCK is set to one and a Watchdog feed is performed, hardware prevents changes to the Watchdog Clock Divider (WDT0CLKDIV) register. LOCK can be set once by software and is only cleared by any reset.

## 27.2 Overview

WWDT helps you reset or interrupt a microcontroller within a programmable time, if the microcontroller (or core) is stuck in an infinite loop or is executing an unintended code. If an application fails to reload or feed a watchdog (WDOG) timer within the predefined duration of time, it generates a watchdog reset (if enabled).

#### 27.2.1 Block diagram

In the following WWDT block diagram, the synchronization logic (APB bus clock to WDCLK) is not shown. See the chip-specific WWDT information for more.



Figure 84. Block diagram

### 27.2.2 Features

- Can reset or interrupt the microcontroller within a programmable time
- Watchdog reset indication flag
- Clocking features:
  - Programmable 24-bit timer with an internal fixed (divided by 4) prescaler
  - Selectable time period in increments of four watchdog clocks: From 1024 watchdog clocks ( $T_{WDCLK} \times 256 \times 4$ ) to over 67 million watchdog clocks ( $T_{WDCLK} \times 2^{24} \times 4$ )

- Watchdog clock (WDCLK) source having a selectable frequency in the range of 6 kHz to 1.5 MHz (see the chip-specific information section and the Clocking chapter for detailed setting in this device)
- Can be configured to run in Low-Power mode (see the chip-specific information section and the Power Management chapter for detailed setting in this device)
- Optional features:
  - Windowed operation requiring a watchdog reload to occur between a programmable minimum and maximum timeout period
  - Generation of a warning interrupt at a programmable time before watchdog timeout
  - Protection of the watchdog reload value so that you can change it only after the warning interrupt time is reached
  - Ability to perform a safe operation, which requires a hardware reset or a watchdog reset to be disabled

## 27.3 Functional description

When you program a watchdog window (a timing window), an early watchdog reload is also treated as a watchdog event, which prevents situations where a system failure may still reload the watchdog timer. For example, the application code could be stuck in an interrupt service that contains a watchdog reload (feed). You must set the timing window in a way that this situation causes an early watchdog timer reload, which generates a watchdog event, and then enables the system to recover from this situation.

WWDT consists of a fixed (divided by 4) prescaler and a 24-bit counter. The minimum value of the counter is FFh; if you write a value lower than FFh, the counter automatically loads with the value FFh.

- Minimum watchdog interval is ( $T_{WDCLK} \times 256 \times 4$ ).
- Maximum watchdog interval is ( $T_{WDCLK} \times 2^{24} \times 4$ ) in multiples of ( $T_{WDCLK} \times 4$ ).

### 27.3.1 Operating modes

This section describes all functional operating modes of the WWDT module: Disabled, Watchdog Interrupt, and Watchdog Reset.

Table 163. Watchdog operating modes selection

| <b>MOD[WDEN]</b> | <b>MOD[WDRESET]</b> | Mode               | Mode description                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------|---------------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                | X (0 or 1)          | Disabled           | Debugs or operates without the watchdog running.                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1                | 0                   | Watchdog Interrupt | Generates a watchdog warning interrupt but does not enable the watchdog reset.<br><br>A watchdog counter equal to the value of <a href="#">WARNINT[WARNINT]</a> sets <a href="#">MOD[WDINT]</a> and generates a watchdog interrupt request.                                                                                                                                                                                                                 |
| 1                | 1                   | Watchdog Reset     | Enables both the watchdog interrupt and watchdog reset: <ul style="list-style-type: none"> <li>• A watchdog counter equal to the value of <a href="#">WARNINT[WARNINT]</a> sets <a href="#">MOD[WDINT]</a> and generates a watchdog interrupt request.</li> <li>• A watchdog counter equal to 0 resets the microcontroller.</li> <li>• A watchdog feed before reaching the value of <a href="#">WINDOW[WINDOW]</a> also causes a watchdog reset.</li> </ul> |

### 27.3.2 Example timing diagrams to show WWDT in operation

A feed is correct when both of the following conditions are true:

- A valid feed sequence completes, writing AAh followed by 55h to [FEED\[FEED\]](#).

- The value of **TV[COUNT]** is not greater than the value of **WINDOW[WINDOW]**.

If either of these conditions is not true, a feed error occurs.

In the correct watchdog feed with Windowed mode enabled, the sequence of writing AAh followed by 55h occurs when the counter value (11FCCh) is not greater than the value of **WINDOW[WINDOW]** (1200h). It is a correct feed (reload) event. After the correct feed event occurs, the watchdog counter reloads with the **TC[COUNT]** value (2000h).

In addition to the above two conditions, when **MOD[WDPROTECT]** = 1, the watchdog counter must not be greater than the value of **WARNINT[WARNINT]** for a correct feed to occur. See the following figure for a pictorial representation.



A correct feed sequence can only occur when the value of **TV[COUNT]** is not greater than the value of **WINDOW[WINDOW]** (1200h). Otherwise, a feed error occurs.

The following figure shows a reset trigger when you feed the watchdog too early.

An early feed event occurs if the feed sequence occurs when the watchdog counter value (1257h) is greater than the value of **WINDOW[WINDOW]** (1200h). This feed error can generate a reset if **MOD[WDRESET]** = 1.



The following figure shows WWDT generating a warning.



### 27.3.3 Clocking

WWDT uses two clocks: APB bus clock and WDCLK.

- The system clock derives the APB bus clock that is used for APB accesses to the watchdog registers.
- The watchdog oscillator derives WDCLK that is used for watchdog timer counting.

The synchronization logic between the two clock domains works as follows:

- When updating [Mode \(MOD\)](#) and [Timer Constant \(TC\)](#), the new value takes effect in three WDCLK cycles on the logic in the WDCLK clock domain.
- When the watchdog timer is counting on WDCLK, the synchronization logic first locks the value of the counter on WDCLK and then synchronizes it with the APB bus clock, so that the CPU can read [Timer Value \(TV\)](#).

#### NOTE

Because of the synchronization step, you must add a delay of three WDCLK clock cycles between the feed sequence and the time that you take to enable the functionality of [MOD\[WDPROTECT\]](#). The length of the delay depends on the selected watchdog clock, WDCLK.

### 27.3.4 Using the WWDT lock

WWDT supports lock features to ensure continuous operation. These features prevent:

- The disabling of the WWDT clock source.
- The changing of the WWDT reload value.

#### 27.3.4.1 Preventing the disabling of the WWDT clock source

If [MOD\[LOCK\]](#) = 1, the WWDT clock source is locked. You cannot disable the clock source when entering Sleep or Deep-Sleep modes. Therefore, enable the watchdog oscillator for each Power mode before writing 1 to [MOD\[LOCK\]](#).

#### 27.3.4.2 Preventing the changing of the WWDT reload value

If [MOD\[WDPROTECT\]](#) = 1, then any attempt to change the value of [TC\[COUNT\]](#) with a feed sequence, before the watchdog counter value becomes less than the values of [WARNINT\[WARNINT\]](#) and [WINDOW\[WINDOW\]](#), sets [MOD\[WDTOF\]](#) and causes a watchdog reset.

Any type of reset disables the reload overwrite lock mechanism.

## 27.4 External signals

This module has no external signals.

## 27.5 Initialization

Perform the following steps to initialize WWDT:

1. Enable and configure the watchdog oscillator.
2. Set the watchdog timer constant reload value using [TC\[COUNT\]](#).
3. Set the watchdog timer operating mode using [MOD\[WDPROTECT\]](#).
4. Set a value for the watchdog window time using [WINDOW\[WINDOW\]](#) if the windowed operation is desired.
5. Set a value for the watchdog warning interrupt using [WARNINT\[WARNINT\]](#) if a warning interrupt is desired.
6. Enable the watchdog by writing AAh followed by 55h to [FEED\[FEED\]](#).

To prevent a watchdog event, you must feed or reload WWDT again before the watchdog counter reaches 0. If you set a value for the watchdog window time, then the feed or reload must also occur after the watchdog counter passes the value of [WINDOW\[WINDOW\]](#).

After you configure WWDT in a way that a watchdog event causes a reset ([MOD\[WRESET\]](#) = 1), or when the counter reaches 0 (it causes a reset), then the microcontroller (or core) is also reset (loading the stack pointer and program counter from the vector table, just like the way it happens for an external reset).

## 27.6 Memory map and register definition

This section includes the WWDT module memory map and detailed descriptions of all registers.

### 27.6.1 WWDT register descriptions

#### 27.6.1.1 WWDT memory map

WWDTO base address: 4000\_C000h

| Offset | Register                                                  | Width<br>(In bits) | Access | Reset value                 |
|--------|-----------------------------------------------------------|--------------------|--------|-----------------------------|
| 0h     | <a href="#">Mode (MOD)</a>                                | 32                 | RW     | 0000_0000h                  |
| 4h     | <a href="#">Timer Constant (TC)</a>                       | 32                 | RW     | 0000_00FFh                  |
| 8h     | <a href="#">Feed Sequence (FEED)</a>                      | 32                 | RW     | <a href="#">See section</a> |
| Ch     | <a href="#">Timer Value (TV)</a>                          | 32                 | R      | 0000_00FFh                  |
| 14h    | <a href="#">Warning Interrupt Compare Value (WARNINT)</a> | 32                 | RW     | 0000_0000h                  |
| 18h    | <a href="#">Window Compare Value (WINDOW)</a>             | 32                 | RW     | 00FF_FFFFh                  |

#### 27.6.1.2 Mode (MOD)

Offset

| Register | Offset |
|----------|--------|
| MOD      | 0h     |

**Function**

Controls the operation of WWDT. You must perform a watchdog feed before any changes to this register take effect.

**NOTE**

After you write 1 to **MOD[WDEN]**, **MOD[WDPROTECT]**, or **MOD[WDRESET]**, you can return those fields to 0 only with an external reset or a WWDT reset. Until those resets occur, writing 0 to the aforementioned fields has no effect.

**Diagram****Fields**

| Field                 | Function                                                                                                                                                                                                                                                                                        |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-7<br>—             | Reserved                                                                                                                                                                                                                                                                                        |
| 6<br><b>DEBUG_EN</b>  | <p>Debug Enable</p> <p><b>NOTE</b></p> <p>This bit can only be written when the chip is in Debug mode.</p> <p>Enables WWDT to operate when the chip is in Debug mode. After you write 1 to this field, you cannot change the value of the field to 0.</p> <p>0b - Disabled<br/>1b - Enabled</p> |
| 5<br><b>LOCK</b>      | <p>Lock</p> <p>Prevents disabling or powering down of the watchdog oscillator after you write 1 to this field and perform a watchdog feed. You can write 1 to this field, which can become 0 only with a reset.</p> <p>0b - No Lock<br/>1b - Lock</p>                                           |
| 4<br><b>WDPROTECT</b> | <p>Watchdog Update Mode</p> <p>Protects the value of <b>TC[COUNT]</b> from changing at any time. In Flexible mode (when this field is 0), you can change the value of <b>TC[COUNT]</b> at any time. In Threshold mode (when this field</p>                                                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | <p>is 1), you can change the value of <b>TC[COUNT]</b> only after the counter is less than the individual values of <b>WARNINT[WARNINT]</b> and <b>WINDOW[WINDOW]</b>. Any attempt to change the value of <b>TC[COUNT]</b> with a feed sequence, before the watchdog counter value becomes less than the values of <b>WARNINT[WARNINT]</b> and <b>WINDOW[WINDOW]</b>, sets <b>MOD[WDTOF]</b> and causes a watchdog reset.</p> <p>You can write 1 to this field, which can become 0 only with a reset (see <a href="#">the note in MOD register</a>).</p> <p>0b - Flexible<br/>1b - Threshold</p>                                                    |
| 3<br>WDINT   | <p>Warning Interrupt Flag</p> <p>Sets the flag when the timer is at or below the value defined in <b>WARNINT[WARNINT]</b>.</p> <p>Note that you cannot clear this flag while the value of <b>WARNINT[WARNINT]</b> is equal to the value of <b>TV[COUNT]</b>. This can occur if the value of both <b>WARNINT[WARNINT]</b> and <b>MOD[WDRESET]</b> is 0 when <b>TV[COUNT]</b> decrements to 0.</p> <p>When you configure WWDT to generate a warning interrupt, the interrupt occurs when the counter is no longer greater than the value defined by <b>WARNINT[WARNINT]</b>.</p> <p>Any reset clears this flag.</p> <p>0b - No flag<br/>1b - Flag</p> |
| 2<br>WDTOF   | <p>Watchdog Timeout Flag</p> <p>The bit could be set if:</p> <ul style="list-style-type: none"> <li>• Watchdog timer timeout has occurred</li> <li>• Feed error has occurred</li> </ul> <p>You must clear this flag by writing 0 to it. An external reset or POR clears this flag too.</p> <p>0b - Watchdog event has not occurred.<br/>1b - Watchdog event has occurred (causes a chip reset if WDRESET = 1).</p>                                                                                                                                                                                                                                  |
| 1<br>WDRESET | <p>Watchdog Reset Enable</p> <p>Allows a watchdog timeout to cause a chip reset, if this field = 1. After you write 1 to this field, you cannot write 0 to it (see <a href="#">the note in MOD register</a>).</p> <p>0b - Interrupt<br/>1b - Reset</p>                                                                                                                                                                                                                                                                                                                                                                                              |
| 0<br>WDEN    | <p>Watchdog Enable</p> <p>Enables or disables the watchdog timer. After writing 1 to this field, perform a watchdog feed (reload) to enable the watchdog timer. After you write 1 to this field, you cannot write 0 to it (see <a href="#">the note in MOD register</a>).</p> <p>0b - Timer stopped<br/>1b - Timer running</p>                                                                                                                                                                                                                                                                                                                      |

### 27.6.1.3 Timer Constant (TC)

#### Offset

| Register | Offset |
|----------|--------|
| TC       | 4h     |

#### Function

Specifies the desired timeout value. Transferring the value of this register into the watchdog counter requires a feed sequence. The register resets to 00\_00FFh. Writing a value below FFh causes 00\_00FFh to load into the register. Therefore, the minimum timeout interval is  $T_{WDCLK} \times 256 \times 4$ .

If [MOD\[WDPROTECT\]](#) = 1, then any attempt to change the value of this register with a feed sequence, before the watchdog counter value becomes less than the individual values of [WARNINT\[WARNINT\]](#) and [WINDOW\[WINDOW\]](#), sets [MOD\[WDTOF\]](#) and causes a watchdog reset.

#### Diagram



#### Fields

| Field         | Function                                                                |
|---------------|-------------------------------------------------------------------------|
| 31-24<br>—    | Reserved                                                                |
| 23-0<br>COUNT | Watchdog Timeout Value<br>Specifies the desired timeout value for WWDT. |

### 27.6.1.4 Feed Sequence (FEED)

#### Offset

| Register | Offset |
|----------|--------|
| FEED     | 8h     |

## Function

Reloads the watchdog timer with the [TC\[COUNT\]](#) value, if you write AAh followed by 55h to [FEED\[FEED\]](#). This operation also starts WWDT, if the watchdog timer is enabled by writing 1 to [MOD\[WDEN\]](#).

However, writing 1 to [MOD\[WDEN\]](#) is not sufficient to enable WWDT. Before the watchdog can generate a reset, [MOD\[WDEN\]](#) must be 1, followed by a valid feed sequence that completes itself. Until then, the watchdog ignores feed errors.

After writing AAh to [FEED\[FEED\]](#), access to any watchdog register other than writing 55h to [FEED\[FEED\]](#) causes an immediate reset or interrupt when WWDT is enabled and sets [MOD\[WDTOF\]](#). An incorrect access to a watchdog register during a feed sequence generates the reset during the second APB bus clock.

To avoid an unintended interrupt, it is a good practice to disable interrupts around a feed sequence. Disable interrupts if they may result in rescheduling processor control away from the current task in the middle of the feed, and then lead to some other access to WWDT before control returns to the interrupted task.

If the value of [WINDOW\[WINDOW\]](#) is less than the default value, it may limit the time for which a watchdog feed is allowed.

## Diagram

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

## Fields

| Field | Function                                                     |
|-------|--------------------------------------------------------------|
| 31-8  | Reserved                                                     |
| —     |                                                              |
| 7-0   | Feed Value                                                   |
| FEED  | Specifies feed value. The value must be AAh followed by 55h. |

## 27.6.1.5 Timer Value (TV)

### Offset

| Register | Offset |
|----------|--------|
| TV       | Ch     |

## Function

Contains the current value of the WWDT counter. When the core (or CPU) reads this register, the value of this register is older than the actual value of the timer. Reading the timer using the lock and synchronization procedure takes up to six WDCLK cycles plus six APB bus clock cycles.

## Diagram

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

## Fields

| Field | Function                                           |
|-------|----------------------------------------------------|
| 31-24 | Reserved                                           |
| —     |                                                    |
| 23-0  | Counter Timer Value                                |
| COUNT | Specifies the current value of the watchdog timer. |

## 27.6.1.6 Warning Interrupt Compare Value (WARNINT)

### Offset

| Register | Offset |
|----------|--------|
| WARNINT  | 14h    |

### Function

Determines the value of [TV\[COUNT\]](#) that generates a watchdog interrupt. When this value is less than or equal to the value defined by WARNINT, an interrupt generates after the subsequent WDCLK.

A match of the WWDT counter to WARNINT occurs when the lower 10 bits of the timer counter have the same value as the lower 10 bits of WARNINT, and the remaining upper bits of the counter are all 0. This gives a maximum time of 1023 watchdog timer counts (4096 watchdog clocks) for the interrupt to occur before a watchdog event. If WARNINT is 0, then the interrupt occurs at the same time as the watchdog event.

**Diagram**

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

**Fields**

| Field   | Function                                                    |
|---------|-------------------------------------------------------------|
| 31-10   | Reserved                                                    |
| —       |                                                             |
| 9-0     | Watchdog Warning Interrupt Compare Value                    |
| WARNINT | Specifies a timer value that generates a warning interrupt. |

**27.6.1.7 Window Compare Value (WINDOW)****Offset**

| Register | Offset |
|----------|--------|
| WINDOW   | 18h    |

**Function**

Determines the highest timer value ([TV\[COUNT\]](#)) allowed during a watchdog feed. If a feed sequence occurs when the value of [TV\[COUNT\]](#) is greater than the value in [WINDOW\[WINDOW\]](#), a watchdog event occurs.

[WINDOW\[WINDOW\]](#) resets to the maximum value of [TV\[COUNT\]](#), where windowing is not in effect.

**Diagram****Fields**

| Field          | Function                                                                                       |
|----------------|------------------------------------------------------------------------------------------------|
| 31-24<br>—     | Reserved                                                                                       |
| 23-0<br>WINDOW | Watchdog Window Value<br>Specifies the highest timer value in which a watchdog feed can occur. |

# Chapter 28

## Micro-Tick Timer (UTICK)

### 28.1 Chip-specific UTICK information

Table 164. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | UTICK          | <a href="#">UTICK</a>               |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 28.1.1 Module instances

This device has one instance of the UTICK module, UTICK0.

### 28.2 Overview

UTICK is a 31-bit timer that counts down to 0 and then generates an interrupt. Thus, it provides a fixed time interval between interrupts. This is a simple, ultra-low-power timer that can run and wake up the chip from Low-power mode. See chip specific information for low power modes UTICK can wakeup.

#### 28.2.1 Block diagram



Figure 88. Block diagram

## 28.2.2 Features

- Wakes up the chip from Low-power mode.
- Starts with a nonzero value written to [CTRL\[DELAYVAL\]](#).
- Operates using interrupt or software polling mode.
- Includes [Capture \(CAP0 - CAP3\)](#) registers that use external pin transitions as a trigger.

## 28.3 Functional description

### 28.3.1 Operations

Perform the following procedure before using UTICK:

1. Configure [CTRL\[REPEAT\]](#) to either perform a one-time delay or continuous delay.
2. Configure [CTRL\[DELAYVAL\]](#) to specify the delay time value in terms of the timer clock.
3. Configure [CFG\[CAPELn\]](#) to decide the number of events to capture (the maximum is four).
4. Configure [CFG\[CAPPOLn\]](#) to capture the polarity (whether to capture on a positive or negative edge of a signal).

### 28.3.2 Clocking

The UTICK clock is selectable from the following clock inputs:

Table 165. Clocking

| Clock                               | Description                                                                                                                                                                                          |
|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Global functional clock (timer_clk) | <p>This clock is supposed to be on during normal operation. This clock is treated as asynchronous to pclk.</p> <p><b>NOTE</b><br/>See the Chip specific section for more details on UTICK clock.</p> |
| System bus clock (pclk)             | This clock is used only for register reads and writes.                                                                                                                                               |

### 28.3.3 Interrupts

The interrupt is generated when the tick\_count reaches 1h so that on the next rising edge of timer\_clk, it doesn't trigger again automatically. Its associated status field is [STAT\[INTR\]](#).

## 28.4 External signals

| Signal                                         | I/O | Description                                                                                                                              |
|------------------------------------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------|
| UTICK_CAP0, UTICK_CAP1, UTICK_CAP2, UTICK_CAP3 | I   | Capture inputs. Configure the selected transition on a capture pin to load <a href="#">Capture (CAP0 - CAP3)</a> with the counter value. |

## 28.5 Initialization

To initialize UTICK:

1. Enable the clock to the UTICK register interface.
2. Enable UTICK interrupts for waking up from Low-power mode, configure [Control \(CTRL\)](#) register.

3. Configure [Capture Configuration \(CFG\)](#) register to enable UTICK capture functions and selects the polarity of capture triggers.
4. Enable the oscillator that provides the UTICK clock, after writing values corresponding registers UTICK timer works normally.

## 28.6 UTICK register descriptions

### 28.6.1 UTICK memory map

UTICK0 base address: 4000\_B000h

| Offset    | Register                                    | Width<br>(In bits) | Access | Reset value                 |
|-----------|---------------------------------------------|--------------------|--------|-----------------------------|
| 0h        | <a href="#">Control (CTRL)</a>              | 32                 | RW     | 0000_0000h                  |
| 4h        | <a href="#">Status (STAT)</a>               | 32                 | RW     | <a href="#">See section</a> |
| 8h        | <a href="#">Capture Configuration (CFG)</a> | 32                 | RW     | <a href="#">See section</a> |
| Ch        | <a href="#">Capture Clear (CAPCLR)</a>      | 32                 | W      | <a href="#">See section</a> |
| 10h - 1Ch | <a href="#">Capture (CAP0 - CAP3)</a>       | 32                 | R      | 0000_0000h                  |

### 28.6.2 Control (CTRL)

Offset

| Register | Offset |
|----------|--------|
| CTRL     | 0h     |

Function

Resets the counter, which means a new interval is measured if one is in progress.

Diagram

|       |                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bits  | 31                       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| R     | <a href="#">REPE AT</a>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W     |                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bits  | 15                       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     | <a href="#">DELAYVAL</a> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| W     |                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Fields**

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>REPEAT     | Repeat Delay<br>Specifies the frequency of repeat delay.<br>0b - One-time delay<br>1b - Delay repeats continuously                                                                                                                                                                                                                                                                            |
| 30-0<br>DELAYVAL | Tick Interval<br>Specifies the tick interval. The resulting delay is (DELAYVAL + 1) periods of the timer clock.<br>The minimum usable tick interval is one clock cycle, for a delay of two timer clocks. The timer will be stopped when the tick interval is equal to zero.<br>000_0000_0000_0000_0000_0000_0000b - Reserved<br>All other values - Clock cycles as defined in the description |

**28.6.3 Status (STAT)****Offset**

| Register | Offset |
|----------|--------|
| STAT     | 4h     |

**Function**

Indicate the micro timer is working or stopping and any event on output compare channels. The bits are write one to clear.

**Diagram**

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

**Fields**

| Field       | Function                                                                                                                    |
|-------------|-----------------------------------------------------------------------------------------------------------------------------|
| 31-2<br>—   | Reserved                                                                                                                    |
| 1<br>ACTIVE | <p>Timer Active Flag</p> <p>Indicates whether UTICK is currently active.</p> <p>0b - Inactive (stopped)<br/>1b - Active</p> |
| 0<br>INTR   | <p>Interrupt Flag</p> <p>Indicates whether an interrupt is pending.</p> <p>0b - Not pending<br/>1b - Pending</p>            |

**28.6.4 Capture Configuration (CFG)****Offset**

| Register | Offset |
|----------|--------|
| CFG      | 8h     |

**Function**

Enables micro-tick capture functions and selects the polarity of capture triggers.

**Diagram**

**Fields**

| Field         | Function                                                                            |
|---------------|-------------------------------------------------------------------------------------|
| 31-12<br>—    | Reserved                                                                            |
| 11<br>CAPPOL3 | Capture Polarity 3<br>Specifies the capture edge.<br>0b - Positive<br>1b - Negative |
| 10<br>CAPPOL2 | Capture Polarity 2<br>Specifies the capture edge.<br>0b - Positive<br>1b - Negative |
| 9<br>CAPPOL1  | Capture-Polarity 1<br>Specifies the capture edge.<br>0b - Positive<br>1b - Negative |
| 8<br>CAPPOL0  | Capture Polarity 0<br>Specifies the capture edge.<br>0b - Positive<br>1b - Negative |
| 7-4<br>—      | Reserved                                                                            |
| 3<br>CAPEN3   | Enable Capture 3<br>0b - Disable<br>1b - Enable                                     |
| 2<br>CAPEN2   | Enable Capture 2<br>0b - Disable<br>1b - Enable                                     |
| 1<br>CAPEN1   | Enable Capture 1<br>0b - Disable<br>1b - Enable                                     |
| 0<br>CAPEN0   | Enable Capture 0                                                                    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function     |
|-------|--------------|
|       | 0b - Disable |
|       | 1b - Enable  |

## 28.6.5 Capture Clear (CAPCLR)

### Offset

| Register | Offset |
|----------|--------|
| CAPCLR   | Ch     |

### Function

Allows you to clear previous capture values, enabling new captures to take place.

### Diagram



### Fields

| Field        | Function                                                                    |
|--------------|-----------------------------------------------------------------------------|
| 31-4<br>—    | Reserved                                                                    |
| 3<br>CAPCLR3 | Clear Capture 3<br>0b - Does nothing<br>1b - Clears the CAP3 register value |
| 2<br>CAPCLR2 | Clear Capture 2<br>0b - Does nothing<br>1b - Clears the CAP2 register value |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                    |
|--------------|-----------------------------------------------------------------------------|
| 1<br>CAPCLR1 | Clear Capture 1<br>0b - Does nothing<br>1b - Clears the CAP1 register value |
| 0<br>CAPCLR0 | Clear Capture 0<br>0b - Does nothing<br>1b - Clears the CAP0 register value |

## 28.6.6 Capture (CAP0 - CAP3)

### Offset

| Register | Offset |
|----------|--------|
| CAP0     | 10h    |
| CAP1     | 14h    |
| CAP2     | 18h    |
| CAP3     | 1Ch    |

### Function

Contains the micro-tick time value based on any previously captured events. Each capture register is associated with one of the capture trigger inputs.

### Diagram

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

### Fields

| Field | Function                  |
|-------|---------------------------|
| 31    | Captured Value Valid Flag |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field             | Function                                                                                                                                                                                                                                                         |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| VALID             | Specifies whether a valid value is captured, based on a transition of the related UTICK_CAP $n$ pin.<br>Write 1 to the related field in <a href="#">Capture Clear (CAPCLR)</a> to clear this flag.<br>0b - Valid value not captured<br>1b - Valid value captured |
| 30-0<br>CAP_VALUE | Captured Value for the Related Capture Event<br>Specifies the captured value for the related capture event.<br>The captured value is 1 lower than the actual value of UTICK at the moment of the capture event.                                                  |

# Chapter 29

## OS Event Timer (OSTIMER)

### 29.1 Chip-specific OSTIMER information

Table 166. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | OSTIMER        | <a href="#">OSTIMER</a>             |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 29.1.1 Module instances

This device has one instance of the OSTIMER module, OSTIMER0.

### 29.2 Overview

OSTIMER includes a shared 42-bit timer and separate 42-bit match and capture functions for the Cortex-M33 core.

#### 29.2.1 Block diagram



Figure 89. Block diagram

## 29.2.2 Features

- Provides a 42-bit Gray code counter (known as central EVTimer). Using Gray code means that the timer can run at a frequency unrelated to the CPU clock and can still be read by the CPU without a synchronization delay. Gray code is a reflected binary code that changes in a single-bit position for each increment.
- Supports separate functions for CPU:
  - A capture register can copy the main counter value when triggered by a CPU request.
  - A match register can be compared to the main counter and can optionally generate an interrupt or wake-up event.

## 29.3 Functional description

The following sections describe the functional details of this module.

### 29.3.1 Shared event or timestamp timer

The 42-bit shared EVTimer initializes after chip power-up and then counts up continuously. The typical clock for this timer is the 1 MHz low-power oscillator.

This timer is implemented as a Gray code counter that enables the counter to be read asynchronously by any of the processing domains or captured by a capture register running on an asynchronous clock. The output of this shared EVTimer is connected to the processor-specific submodules.

### 29.3.2 CPU-specific match, capture, and interrupt generation

The submodules associated with CPU include:

- A separate bus interface.
- 42 bits of capture values, available in [CAPTURE\\_L](#) and [CAPTURE\\_H](#).
- 42 bits of match values, available in [MATCH\\_H](#) and [MATCH\\_L](#).
- A control register, which includes an interrupt request flag and an interrupt enable field.

|                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Capture registers                     | 42 bits of capture values are available in <a href="#">CAPTURE_L</a> and <a href="#">CAPTURE_H</a> for the CPU. When the CPU issues a capture command, capture registers store the current value of the central EVTimer.                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Match registers and interrupt request | 42 bits of match values are available in <a href="#">MATCH_H</a> and <a href="#">MATCH_L</a> for each bus interface. The EVTimer output is compared against this combined value for interrupt or wake-up generation. A match to this register pair sets <a href="#">OSEVENT_CTRL[OSTIMER_INTRFLAG]</a> , which you can enable to generate an interrupt or wake-up request. You must write values to the match registers in Gray code.<br><br><a href="#">OSEVENT_CTRL[MATCH_WR_RDY]</a> must be 0 before you write to the match registers. When you write a new value to the match registers, you must write to <a href="#">MATCH_L</a> before the write to <a href="#">MATCH_H</a> . |

### 29.3.3 Clocking

The OSTIMER uses three clock signals: hclk, capture\_clk, and ostimer\_clk.

- Hclk is the IPS interface clock for both the Arm and DSP sub-module, being used in all the registers and write/read operations.
- Ostimer\_clk is the counter clock, being used in the timer itself and in the intr\_wakeup signals. It is expected to be running in a low frequency (~1MHz).
- capture\_clk is the Arm and DSP clock, it is used to register the capture signal “capture\_load”.

### 29.3.4 Reset

For OSTIMER, the reset function is more complicated as compared to most other functions.

- Only the POR and software reset can reset the shared EVTimer. "Software reset" refers to a complete reset of the module.
- The capture and match registers are reset by a system reset. "System reset" refers to a reset from the RESET $n$  pin, SYSRESETREQ from the CPU, a POR, or any other internal low-voltage resets.
- The control register (OSEVENT\_CTRL) is reset by the system reset or by software reset. However, the MATCH\_WR\_RDY bit can only be reset by system reset.

The following table shows a list of resets for OSTIMER registers.

Table 167. OSTIMER registers and their corresponding resets

| Registers               | POR | Software reset |
|-------------------------|-----|----------------|
| EVTIMERL and EVTIMERH   | Yes | Yes            |
| CAPTURE_L and CAPTURE_H | Yes | No             |
| OSEVENT_CTRL            | Yes | Yes            |

### 29.3.5 Interrupts

If the interrupt request is enabled (i.e., OSEVENT\_CTRL[OSTIMER\_INTENA]= 1), the OSTIMER will generate interrupt when the central 42-bit EVTimer and the value programmed in MATCH\_L and MATCH\_H matches.

No interrupt generates if the interrupt request is disabled (i.e., OSEVENT\_CTRL[OSTIMER\_INTENA]= 0).

## 29.4 External signals

This module has no external signals.

## 29.5 Initialization

Perform this procedure to initialize OSTIMER:

1. Enable the OSTIMER clock. This enables the register interface and the peripheral function clock.
2. Select a clock source for OSTIMER.
3. Clear the OSTIMER peripheral reset.
4. Enable the interrupt that OSTIMER provides to the interrupt controller (set OSEVENT\_CTRL[OSTIMER\_INTRFLAG]= 1). This allows the chip to wake up from Deep Sleep mode.

## 29.6 Memory map and register definition

This section includes the module's memory map and detailed descriptions of all registers.

### 29.6.1 OSTIMER register descriptions

#### 29.6.1.1 OSTIMER memory map

OSTIMER0 base address: 400A\_D000h

| Offset | Register                               | Width<br>(In bits) | Access | Reset value |
|--------|----------------------------------------|--------------------|--------|-------------|
| 0h     | EVTIMER Low (EVTIMERL)                 | 32                 | R      | 0000_0000h  |
| 4h     | EVTIMER High (EVTIMERH)                | 32                 | R      | 0000_0000h  |
| 8h     | Local Capture Low for CPU (CAPTURE_L)  | 32                 | R      | 0000_0000h  |
| Ch     | Local Capture High for CPU (CAPTURE_H) | 32                 | R      | 0000_0000h  |
| 10h    | Local Match Low for CPU (MATCH_L)      | 32                 | RW     | FFFF_FFFFh  |
| 14h    | Local Match High for CPU (MATCH_H)     | 32                 | RW     | FFFF_FFFFh  |
| 1Ch    | OSTIMER Control for CPU (OSEVENT_CTRL) | 32                 | RW     | 0000_0008h  |

### 29.6.1.2 EVTIMER Low (EVTIMERL)

#### Offset

| Register | Offset |
|----------|--------|
| EVTIMERL | 0h     |

#### Function

Contains the immediate value of the central EVTTimer. This is a Gray encoded counter register that is not synchronized with the bus clock.

Because two 32-bit reads are required to retrieve the entire counter value, it is possible for the counter to roll over between the reads of [EVTIMERL](#) and [EVTIMERH](#). Gray encoding ensures that even if this roll over occurs, the value read represents either the counter value immediately preceding or immediately following the rollover, if the bus clock rate is at least twice the module's clock rate (nominally 1 MHz), or if the bus is clocked by the same 1 MHz LP oscillator that provides the clock to the module.

#### Diagram



**Fields**

| Field                | Function                                                                                                                                                                                               |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0                 | EVTimer Count Value                                                                                                                                                                                    |
| EVTIMER_COUPNT_VALUE | Specifies the current value of the lower 32 bits of the central 42-bit EVTTimer when you read this register.<br><br><b>NOTE</b><br>Only one physical EVTTimer exists and is readable from all domains. |

**29.6.1.3 EVTIMER High (EVTIMERH)****Offset**

| Register | Offset |
|----------|--------|
| EVTIMERH | 4h     |

**Function**

Contains the higher value of the central EVTTimer. This register resets only after POR or a software reset.

**Diagram****Fields**

| Field                       | Function                                                                                                                                                                                                                      |
|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-10<br>—                  | Reserved                                                                                                                                                                                                                      |
| 9-0<br>EVTIMER_COUPNT_VALUE | EVTimer Count Value<br>Specifies the current value of the upper 10 bits of the central 42-bit EVTTimer when you read this register.<br><br><b>NOTE</b><br>Only one physical EVTTimer exists and is readable from all domains. |

### 29.6.1.4 Local Capture Low for CPU (CAPTURE\_L)

#### Offset

| Register  | Offset |
|-----------|--------|
| CAPTURE_L | 8h     |

#### Function

Contains the value of the central EVTimer when captured by the CPU. This register is Gray encoded to match EVTimer. You must not execute a new capture command between reading [CAPTURE\\_L](#) and [CAPTURE\\_H](#), to avoid retrieving incoherent results.

#### Diagram

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

#### Fields

| Field             | Function                                                                                                                                                                                                                                                                                                                              |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0              | EVTimer Capture Value                                                                                                                                                                                                                                                                                                                 |
| CAPTURE_VAL<br>UE | Specifies the value of the lower 32 bits of the central 42-bit EVTimer when you read this register, at the time that the CPU generated the last capture signal. A separate pair of <a href="#">CAPTURE_L</a> and <a href="#">CAPTURE_H</a> is implemented for the CPU. CPU reads its own capture value at the same pair of addresses. |

### 29.6.1.5 Local Capture High for CPU (CAPTURE\_H)

#### Offset

| Register  | Offset |
|-----------|--------|
| CAPTURE_H | Ch     |

#### Function

Contains the value of the central EVTimer when captured by the CPU. This register is Gray encoded to match EVTimer. You must not execute a new capture command between reading [CAPTURE\\_L](#) and [CAPTURE\\_H](#), to avoid retrieving incoherent results.

**Diagram****Fields**

| Field                    | Function                                                                                                                                                                                                                                |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-10<br>—               | Reserved                                                                                                                                                                                                                                |
| 9-0<br>CAPTURE_VAL<br>UE | EVTimer Capture Value<br>Specifies the value of the upper 10 bits of the central 42-bit EVTtimer when you read this register, at the time the CPU generated the last capture signal (using CMSIS C function " <code>__SEV();</code> "). |

**29.6.1.6 Local Match Low for CPU (MATCH\_L)****Offset**

| Register | Offset |
|----------|--------|
| MATCH_L  | 10h    |

**Function**

Compares the match value with the central EVTtimer value. This register is Gray encoded to match EVTtimer. The value in this pair of registers is stable, so there is no need for multiple reads. When writing to the match register pair, you must write to **MATCH\_L** first, followed by the write to **MATCH\_H**.

You must not initiate a second write to the match register pair until the first write is complete (which is a minimum of three bus clocks followed by a write to **MATCH\_H**). **OSEVENT\_CTRL[MATCH\_WR\_RDY]** indicates when it is safe to reload the match registers. You do not need to read **OSEVENT\_CTRL[MATCH\_WR\_RDY]** if an interrupt has already occurred because of the previous match value, or the required time period has elapsed.

**Diagram**

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

**Fields**

| Field                   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>MATCH_VALU<br>E | EVTimer Match Value<br><br>Compares the value (lower 32 bits) of the <a href="#">MATCH_L</a> and <a href="#">MATCH_H</a> register pair with the central EVTtimer value. If both the values match, the CPU generates an interrupt request if the interrupt is enabled.<br><br>A separate pair of <a href="#">MATCH_L</a> and <a href="#">MATCH_H</a> is implemented for the CPU reading its own local value at the same pair of addresses. |

**29.6.1.7 Local Match High for CPU (MATCH\_H)****Offset**

| Register | Offset |
|----------|--------|
| MATCH_H  | 14h    |

**Function**

Compares the match value with the central EVTtimer value. This register is Gray encoded to match EVTtimer. The value in this pair of registers is stable, so there is no need for multiple reads. When writing to the match register pair, you must write to [MATCH\\_L](#) first, followed by the write to [MATCH\\_H](#).

You must not initiate a second write to the match register pair until the first write is complete (which is a minimum of three bus clocks followed by a write to [MATCH\\_H](#)). [OSEVENT\\_CTRL\[MATCH\\_WR\\_RDY\]](#) indicates when it is safe to reload the match registers. You do not need to read [OSEVENT\\_CTRL\[MATCH\\_WR\\_RDY\]](#) if an interrupt has already occurred because of the previous match value, or the required time period has elapsed.

**Diagram****Fields**

| Field                  | Function                                                                                                                                                                                                                          |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-10<br>—             | Reserved                                                                                                                                                                                                                          |
| 9-0<br>MATCH_VALU<br>E | EVTimer Match Value<br>Compares the value (upper 10 bits) of the MATCH_L and MATCH_H register pair with the central EVTtimer value. If both the values match, the CPU generates an interrupt request if the interrupt is enabled. |

**29.6.1.8 OSTIMER Control for CPU (OSEVENT\_CTRL)****Offset**

| Register     | Offset |
|--------------|--------|
| OSEVENT_CTRL | 1Ch    |

**Function**

Provides the interrupt flag and interrupt enable signals for the CPU. A separate OSEVENT\_CTRL register is implemented for the CPU. CPU reads its own local value at the same address.

**Diagram**

**Fields**

| Field                  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4<br>—              | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3<br>DEBUG_EN          | <p>Debug Enable</p> <p>Enables OSTIMER to operate when the chip is in Debug mode. This is a write-once field.</p> <p>0b - Disables<br/>1b - Enables</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2<br>MATCH_WR_RDY      | <p>EVTimer Match Write Ready</p> <p>Specifies that when this field is low, it is safe to reload (write) to the match registers. In typical applications, it is not necessary to read this field.</p> <p>The 42-bit match register value is transferred from a pair of shadow registers to the active match registers after you write to <a href="#">MATCH_H</a>. You must not initiate a second write to <a href="#">MATCH_L</a> and <a href="#">MATCH_H</a> until after this transfer completes. This field becomes 0 after the transfer completes.</p> <p>It is not necessary to read this status field, if an interrupt has already occurred because of the first match value, or if it is certain (via some other means) that the required period of time (3 bus clocks) has elapsed.</p> |
| 1<br>OSTIMER_INT_ENA   | <p>Interrupt or Wake-Up Request</p> <p>This bit is to enable/disable interrupt request. If the value is 1, then this field asserts an interrupt or wake-up request to the domain processor. Otherwise, the interrupt or wake-up requests are blocked.</p> <p>0b - Interrupts blocked<br/>1b - Interrupts enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0<br>OSTIMER_INT_RFLAG | <p>Interrupt Flag</p> <p>Sets an interrupt flag when a match occurs between the central 42-bit EVTtimer and the value programmed in the <a href="#">MATCH_L</a> and <a href="#">MATCH_H</a> register pair for the CPU.</p> <p>Writes to clear this field are asynchronous. You must write 1 to this field before writing a new match value into <a href="#">MATCH_L</a> and <a href="#">MATCH_H</a>.</p>                                                                                                                                                                                                                                                                                                                                                                                      |

# Chapter 30

## Wake-Up Timer

### 30.1 Chip-specific Wake-up Timer information

Table 168. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | WAKEUPTIMER    | <a href="#">Wake-up Timer</a>       |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 30.1.1 Module instances

This device has one instance of the Wakeup Timer module, WAKEUPTIMER0.

### 30.2 Overview

The wake timer is clocked by the 1 kHz clock which is the output of the WAKE\_TIMER\_CTRL[OSC\_DIV\_ENA], the clock divider of the clock source.

#### 30.2.1 Block diagram



Figure 90. WAKEUP TIMER block diagram

#### 30.2.2 Features

- 32-bit wake-up timer counter to wake the chip.

### 30.3 Functional description

The wake timer is a 32-bit down counter, which is clocked at a 1 kHz rate when enabled. Writing any non-zero value to this timer automatically enables the counter and launches a countdown sequence. When the counter is being used as a wake timer, this write can occur prior to entering a low-power mode.

When a starting count value loads, the wake timer turns on, counts from the pre-loaded value down to zero, generates an interrupt and/or a wake command, and then turns itself off until relaunched by a subsequent software write.

### 30.4 External signals

This module has no external signals.

### 30.5 Memory map and register description

This section includes the WAKEUP\_TIMER memory map and detailed descriptions of all registers.

#### 30.5.1 WAKEUP\_TIMER register descriptions

##### 30.5.1.1 WAKEUP\_TIMER memory map

WAKETIMER0 base address: 400A\_E000h

| Offset | Register                             | Width<br>(In bits) | Access | Reset value |
|--------|--------------------------------------|--------------------|--------|-------------|
| 0h     | Wake Timer Control (WAKE_TIMER_CTRL) | 32                 | RW     | 0000_0000h  |
| Ch     | Wake Timer Counter (WAKE_TIMER_CNT)  | 32                 | RW     | 0000_0000h  |

##### 30.5.1.2 Wake Timer Control (WAKE\_TIMER\_CTRL)

###### Offset

| Register        | Offset |
|-----------------|--------|
| WAKE_TIMER_CTRL | 0h     |

###### Function

The wake timer is clocked by the 1 kHz clock which is the output of the 4-bit ripple counter with the 16 kHz clock as the clock source. This register controls the wake timer counter register.

**Diagram****Fields**

| Field               | Function                                                                                                                                                                                                                                   |
|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-6<br>—           | Reserved                                                                                                                                                                                                                                   |
| 5<br>INTR_EN        | Enable Interrupt<br>Enable interrupt when WAKE_FLAG is set.<br>0b - Disabled<br>1b - Enabled                                                                                                                                               |
| 4<br>OSC_DIV_ENA    | OSC Divide Enable<br>Enables the 4-bit clock divider to divide down the 16 kHz input clock to generate the 1 kHz clock source for the wake timer. OSC_DIV_ENA must be set to 1 for the wake timer to run.<br>0b - Disabled<br>1b - Enabled |
| 3<br>—              | Reserved                                                                                                                                                                                                                                   |
| 2<br>CLR_WAKE_TIMER | Clear Wake Timer<br><br>————— NOTE ————<br>Reading this bit always returns 0.<br><br>0b - No effect.<br>1b - Clears the wake timer counter and halts operation until a new count value is loaded.                                          |
| 1<br>WAKE_FLAG      | Wake Timer Status Flag<br>Writing 1 clears this status bit. Writing 0 has no effect.                                                                                                                                                       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field  | Function                                                             |
|--------|----------------------------------------------------------------------|
|        | 0b - Wake timer has not timed out.<br>1b - Wake timer has timed out. |
| 0<br>— | Reserved                                                             |

### 30.5.1.3 Wake Timer Counter (WAKE\_TIMER\_CNT)

#### Offset

| Register       | Offset |
|----------------|--------|
| WAKE_TIMER_CNT | Ch     |

#### Function

Do not write to WAKE\_TIMER\_CNT while counting is in progress.

#### Diagram



#### Fields

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>WAKE_CNT | Wake Counter<br><br>A read reflects the current value of the wake timer. Due to clock domain crossing, read the register twice in succession and confirm that the two values are the same. If the values are not the same, repeat the procedure until the two values are the same.<br><br>A write to this field pre-loads a start-count value into the timer and starts a countdown sequence. |

# Chapter 31

## Enhanced Flex Pulse Width Modulator (eFlexPWM)

### 31.1 Chip-specific eFlexPWM information

Table 169. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | eFlexPWM       | <a href="#">eFlexPWM</a>            |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Bus and Memories    |                | <a href="#">Memory architecture</a> |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 31.1.1 Module instances

This device has one instance of the PWM module, PWM0.

#### 31.1.2 PWM control signals

This device doesn't support PWM\_A and PWM\_B capture functions (only PWM\_X is supported). Any references of PWM\_A and PWM\_B should be ignored throughout the chapter.

### 31.2 Overview

The Pulse Width Modulator (PWM) module contains PWM submodules, each of which can be used to control a single half-bridge power stage. Fault channel support is provided.

This module generates various switching patterns, including highly sophisticated waveforms. It is ideal for controlling different Switched Mode Power Supplies (SMPS) topologies.

#### 31.2.1 Block diagram

The following figure shows the PWM block diagram.



Figure 91. PWM block diagram

### 31.2.2 Features

Following are the features of PWM:

- 16-bit resolution for center, edge-aligned, and asymmetrical PWMs
- Dithering to simulate enhanced resolution when fine edge placement is not available
- PWM outputs that can operate as complementary pairs or independent channels
- Ability to accept signed numbers for PWM generation
- Independent control of both edges of each PWM output
- Support for synchronization to external hardware or other PWM
- Double buffered PWM registers
  - Integral reload rates from 1 to 16
  - Half cycle reload capability
- Multiple output trigger events can be generated per PWM cycle via hardware
- Support for double switching PWM outputs
- Fault inputs can be assigned to control multiple PWM outputs

- Programmable filters for fault inputs
- Independently programmable PWM output polarity
- Independent top and bottom deadtime insertion
- Each complementary pair can operate with its own PWM frequency and deadtime values
- Individual software control for each PWM output
- All outputs can be programmed to change simultaneously via a FORCE\_OUT event
- PWM\_X pin can optionally output a third PWM signal from each submodule
- Channels not used for PWM generation can be used for buffered output compare functions and for input capture functions
- Enhanced dual edge capture functionality

### 31.3 Functional description

#### 31.3.1 PWM submodule

The following figure shows the PWM Submodule Block Diagram.



#### 31.3.2 PWM capabilities

This section describes some capabilities of the PWM module.

### 31.3.2.1 Center aligned PWMs

Each submodule has its own timer that is capable of generating PWM signals on two output pins. The edges of each of these signals are controlled independently as shown in [Figure 93](#).



**Figure 93.** Center aligned PWM example

The submodule timers only count in the up direction and then reset to the INIT value. Instead of having a single value that determines pulse width, there are two values that must be specified: the turn-on edge and the turn-off edge. This double-action edge generation provides the user control over the pulse width and also the relative alignment of the signal. As a result, there is no need to support separate PWM alignment modes since the PWM alignment mode is inherently a function of the turn-on and turn-off edge values.

[Figure 93](#) also illustrates an additional enhancement to the PWM generation process. When the counter resets, it is reloaded with a user-specified value, which may or may not be zero. If the value chosen happens to be the 2's complement of the modulus value, then the PWM generator operates in "signed" mode. This means if each PWM's turn-on and turn-off edge values are same in numbers but different in their sign, the "on" portion of the output signal is centered around a count value of zero. Therefore, only one PWM value is calculated in software and then this value and its negative are provided to the submodule as the turn-off and turn-on edges respectively. This technique results in a pulse width consists of an odd number of timer counts. If all PWM signal edge calculations follow this convention, then the signals will be center aligned with each other, which is the goal. The center alignment between the signals is not restricted to symmetry around the zero count value, as any other number would also work. However, centering on zero provides the greatest range in signed mode and also simplifies the calculations.

### 31.3.2.2 Edge aligned PWMs

[Figure 94](#) shows the results of edge aligned operation when the turn-on edge for each pulse is specified to be the INIT value. Therefore, only the turn-off edge value needs to be periodically updated to change the pulse width.



Figure 94. Edge aligned example (INIT=VAL2=VAL4)

With edge aligned PWMs, another example of the benefits of signed mode can be seen. Use "bipolar" PWMs to drive an H-bridge, where a 50% duty cycle results in zero volts on the load. Duty cycles less than 50% generate negative load voltages and duty cycles greater than 50% generate positive load voltages. If the module is set to signed mode operation (the INIT and VAL1 values are the same number with opposite signs), then there is a direct proportionality between the PWM turn-off edge value and the motor inverter voltage, including the sign. Therefore, signed mode of operation simplifies the software interface to the PWM module since no offset calculations are required to translate the output variable control algorithm to the voltage on an H-Bridge load.

### 31.3.2.3 Phase shifted PWMs

In the previous sections, the benefits of the signed mode of operation were discussed in the context of simplifying the required software calculations by eliminating the requirement to bias up signed variables before applying them to the module. However, if numerical biases are applied to the turn-on and turn-off edges of different PWM signals, the signals will be phase shifted to each other, as shown in Figure 95. This results in certain advantages when applied to a power stage. For example, when operating a multi-phase inverter at a low modulation index, all of the PWM switching edges from the different phases occur at the same time. This can be troublesome from a noise standpoint, especially if ADC readings of the inverter must be scheduled near those times. Phase shifting the PWM signals can open up timing windows between the switching edges to allow a signal to be sampled by the ADC. However, phase shifting does not affect the duty cycle so average load voltage is not affected.

If the outputs of submodules 1 - 2 need to be delayed from the output of submodule 0 (and from each other), instead of just creating a phase delay by adding an offset to the turn on and turn off times of the different submodules, another method is to use the PHASEDLY registers for submodules 1 - 2 to indicate their delay from the submodule 0 timing. This method can be used when the master sync signal from submodule 0 is selected as the initialization source (CTRL2[INIT\_SEL]==b10). This method allows all of the submodules to be programmed with the same turn on and turn off time but submodules 1 - 2 can still be delayed the time from submodule 0.



Figure 95. Phase shifted outputs - example for 1 submodule

An additional benefit of phase shifted PWMs is shown in [Figure 96](#). In this case, an H-Bridge circuit is driven by 4 PWM signals to control the voltage waveform on the primary of a transformer. Both left and right side PWMs are configured to generate a square wave with 50% duty cycle. This works for the H-Bridge since no narrow pulse widths are generated reducing the high frequency switching requirements of the transistors. The RMS value of this waveform is directly controlled by the amount of phase shift of the square waves. Regardless of the phase shift, no DC component appears in the load voltage as long as the duty cycle of each square wave remains at 50% suitable for transformer loads. As a result, this topology is frequently used in industrial welders to adjust the amount of energy delivered to the weld arc.

#### NOTE

The square wave on the right side of the H-Bridge is phase shifted compared to the left side of the H-Bridge. As a result, the transformer primary sees the bottom waveform across its terminals.



Figure 96. Phase Shifted PWMs Applied to a Transformer Primary

### 31.3.2.4 Double switching PWMs

Double switching PWM output is supported to aid in single shunt current measurement and three-phase reconstruction. This method supports two independent rising edges and two independent falling edges per PWM cycle. The VAL2 and VAL3 registers are used to generate the even channel (labeled as PWM\_A in Figure 97) while VAL4 and VAL5 are used to generate the odd channel. The two channels (PWM23 or PWM\_A and PWM45 or PWM\_B from force out logic) are combined using XOR logic (force out logic) as the following figure shows. The DBLPWM signal can be run through the deadtime insertion logic.



Figure 97. Double switching output example

### 31.3.2.5 ADC triggering

In cases where the timing of the ADC triggering is critical, it must be scheduled as a hardware event instead of software activated. With this PWM module, multiple ADC triggers can be generated in hardware per PWM cycle without the requirement of another timer module. [Figure 98](#) shows how this is accomplished. When specifying a complementary mode of operation, only two edge comparators are required to generate the output PWM signals for a given submodule. This means the other comparators are free to perform other functions. In this example, the software does not need to quickly respond after the first conversion to set up other conversions that must occur in the same PWM cycle.



Because each submodule has its own timer, it is possible for each submodule to run at a different frequency. One of the options possible with this PWM module is to have one or more submodules running at a lower frequency, but still synchronized to the timer in submodule0. [Figure 99](#) shows how this feature can be used to schedule ADC triggers over multiple PWM cycles. You can use the lower-frequency submodule to control the sampling frequency of the software control algorithm where multiple ADC triggers can now be scheduled over the entire sampling period. In [Figure 99](#), all submodule comparators are shown being used for ADC trigger generation.



Figure 99. Multiple output triggers over several PWM cycles

### 31.3.2.6 Enhanced capture capabilities (E-Capture)

When a PWM pin is not used for PWM generation, it can be used to perform input captures. For PWM generation, both edges of the PWM signals are specified via separate compare register values. When programmed for input capture, both of these registers work on the same pin to capture multiple edges, toggling from one to the other in either a free running or one-shot fashion. Programming the desired edge of each capture circuit, period, and pulse width of an input signal can easily be measured without the requirement to re-arm the circuit. In addition, each edge of the input signal can clock an 8-bit counter where the counter output is compared to a user specified value (EDGCMP). When the counter output equals EDGCMP, the value of the submodule timer is captured and the counter is automatically reset. This feature counts a specified number of edge events and then performs a capture and interrupt. The following figure illustrates some of the functionality of the E-Capture circuit.



Figure 100. Capture capabilities of the E-Capture circuit

When a submodule is used for PWM generation, its timer counts up to the modulus value used to specify the PWM frequency and then is re-initialized. Therefore, using this timer for input captures on one of the other pins (for example, PWM\_X) has limited utility since it does not count through all of the numbers and the timer reset represents a discontinuity in the 16-bit number range. However, when measuring a signal that is synchronous to the PWM frequency, the timer modulus range is suited for the application. As shown in [Figure 101](#), the output of a PWM power stage is connected to the PWM\_X pin that is configured for free running input captures. Specifically, the CVLA0 capture circuitry is programmed for rising edges and the CVLA1 capture circuitry is set for falling edges. This results in new load pulse width data acquired every PWM cycle. To calculate the pulse width, subtract the CVLA0 register value from the CVLA1 register value. This measurement is beneficial when performing deadtime distortion correction on a half bridge circuit driving an inductive load. Also, these values can be directly compared to the VALx registers responsible for generating the PWM outputs to obtain a measurement of system propagation delays. For details, refer to the separate discussion of deadtime distortion correction.



### 31.3.2.7 Synchronous switching of multiple outputs

Before the PWM signals are routed to the output pins, they are processed by a hardware block that permits all submodule outputs to be switched synchronously. This feature is useful in commutated motor applications where the next commutation state can be laid in ahead of time and then immediately switched to the outputs when the appropriate condition or time is reached. All the changes occur immediately after the trigger event occurs eliminating any interrupt latency and also the changes occurs synchronously on all submodule outputs.

The synchronous output switching is accomplished via a signal called FORCE\_OUT. This signal originates from the local FORCE bit within the submodule, from submodule0, or from external to the PWM module, and in most cases, is supplied from an external timer channel configured for output compare. In a typical application, software sets up the desired states of the output pins in preparation for the next FORCE\_OUT event. This selection lays dormant until the FORCE\_OUT signal transitions and then all outputs are switched simultaneously. The signal switching is performed upstream from the deadtime generator so that any abrupt changes that occur do not violate deadtime on the power stage when in complementary mode.

Figure 102 shows an application that can benefit from this feature. On a brushless DC motor in many cases, it is required to spin the motor without need of hall-effect sensor feedback. Instead, the back EMF of the motor phases is monitored and this information is used to schedule the next commutation event. The top waveforms of Figure 102 represent these back EMF signals. Timer compare events (represented by the long vertical lines in the diagram) are scheduled based on the zero crossings of the back-EMF waveforms. The PWM module is configured via software ahead of time with the next state of the PWM pins in anticipation of the compare event. When it happens, the output compare of the timer drives the FORCE\_OUT signal which immediately changes the state of the PWM pins to the next commutation state with no software latency.



### 31.3.3 Operation

This section describes the implementation of various sections of the PWM in detail.

The following figure is a high-level block diagram of output PWM generation.



Figure 103. High-level output PWM generation block diagram

### 31.3.3.1 Register reload logic

The register reload logic is used to determine when the outer set of registers for all double buffered register pairs will be transferred to the inner set of registers. The register reload event can be scheduled to occur every "n" PWM cycles using CTRL[LDFQ] and CTRL[FULL], which is defined by VAL1 register. A half cycle reload option is also supported (CTRL[HALF]) where the reload can take place in the middle of a PWM cycle. The half cycle point is defined by the VAL0 register and does not have to be exactly in the middle of the PWM cycle.

As shown in [Figure 104](#) the reload signal from submodule0 can be broadcast as the Master Reload signal allowing the reload logic from submodule0 to control the reload of registers in other submodules.



Figure 104. Register reload logic of each submodule

### 31.3.3.2 Counter synchronization

As shown in [Figure 105](#), the 16-bit counter counts up until its output equals VAL1 which is used to specify the counter modulus value. The resulting compare causes a rising edge to occur on the Local Synchronization signal which is one of four possible sources used to cause the 16-bit counter to be initialized with INIT. If Local Synchronization is selected as the counter initialization signal, VAL1 within the submodule effectively controls the timer period (and then the PWM frequency generated by that submodule), and everything operates or functions at a local level.



Figure 105. Counter synchronization for each submodule

The Master Synchronization signal originates as the Local Sync from submodule0. If configured to do so, the timer period of any submodule can be locked to the period of the timer in submodule0.

The PWM\_EXT\_SYNC signal originates on chip or off chip depending on the system architecture. This signal may be selected as the source for counter initialization so that an external source can control the period of all submodules.

If the Master Reload signal is selected as the source for counter initialization, then the period of the counter will be locked to the register reload frequency of submodule0. Since the reload frequency is commensurate to the sampling frequency of the software control algorithm, the submodule counter period is equal the sampling period. As a result, this timer can be used to generate output compares or output triggers over the entire sampling period which may consist of several PWM cycles. The Master Reload signal can only originate from submodule0.

The counter can optionally initialize upon the assertion of the FORCE\_OUT signal assuming that CTRL2[FRCEN] is set. As shown in Figure 105, this constitutes a second initialization input into the counter, which causes the counter to initialize regardless of which signal is selected as the counter initialization signal. A forced initialization causes a register reload if MCTRL[LDOCK] is set.

The counter can be initialized by FORCE\_OUT signal only when MCTRL[RUN] = 1 or CTR2[CLK\_SEL] = 2 which chooses auxiliary clock from SM0.

The FORCE\_OUT signal is provided mainly for commutated applications. When PWM signals are commutated on an inverter controlling a brushless DC motor, it is necessary to restart the PWM cycle at the beginning of the commutation interval. This action effectively resynchronizes the PWM waveform to the commutation timing. Otherwise, the average voltage applied to a motor winding integrated over the entire commutation interval will be a function of the timing between the asynchronous commutation event for the PWM cycle. The effect is more critical at higher motor speeds where each commutation interval may consist of only a few PWM cycles. If the counter is not initialized at the start of each commutation interval, the result is an oscillation caused by the beating between the PWM frequency and the commutation frequency.

### 31.3.3.3 PWM generation

Figure 106 illustrates how PWM generation is accomplished in each submodule. In each case, two comparators and associated VALx registers are utilized for each PWM output signal. One comparator and VALx register are used to control the turn-on edge, while a second comparator and VALx register control the turn-off edge.



Figure 106. PWM Generation Hardware of each submodule

The generation of the Local Synchronization signal is performed exactly the same way as the other PWM signals in the submodule. While comparator 0 causes a falling edge of the Local Synchronization signal, comparator 1 generates a rising edge. Comparator 1 is also hardwired to the reload logic to generate the full cycle reload indicator.

If VAL1 is controlling the modulus of the counter and VAL0 is half of the VAL1 register minus the INIT value, then the half cycle reload pulse occurs exactly half way through the timer count period and the Local Synchronization will have a 50% duty cycle. On the other hand, if the VAL1 and VAL0 registers are not required for register reloading or counter initialization, they can be used to modulate the duty cycle of the Local Synchronization signal, effectively turning it into an auxiliary PWM signal (PWM\_X) assuming that the PWM\_X pin is not being used for another function such as input capture or deadtime distortion correction. Including the Local Synchronization signal, each submodule is capable of generating three PWM signals where software has complete control over each edge of each of the signals.

If the comparators and edge value registers are not required for PWM generation, they can be used for other functions such as output compares, generating output triggers, or generating interrupts at timed intervals.

The 16-bit comparators shown in Figure 106 are "equal to" comparators. In addition, if both the set and reset of the flip-flop are asserted, then the flop output goes to 0.

### 31.3.3.4 Output compare capabilities

By using the VALx registers in conjunction with the submodule timer and 16-bit comparators, buffered output compare functionality can be achieved with no additional hardware required. Specifically, the following output compare functions are possible:

- An output compare sets the output high
- An output compare sets the output low
- An output compare generates an interrupt
- An output compare generates an output trigger

In PWM generation, an output compare is initiated by programming a VALx register for a timer compare, which in turn causes the output of the D flip-flop to either set or reset. For example, if an output compare is desired on the PWM\_A signal that sets it high, VAL2 would be programmed with the counter value where the output compare should take place. However, to prevent the D flip-flop from being reset again after the compare has occurred, the VAL3 register must be programmed to a value out of the modulus range of the counter. Therefore, a comparison that would result in resetting the D flip-flop output would never occur. Conversely, if an output compare is desired on the PWM\_A signal that sets it low, the VAL3 register is programmed with the appropriate count value and the VAL2 register is programmed with a value out of the counter modulus range. Regardless of whether a high compare or low compare is programmed, an interrupt, or output trigger can be generated when the compare event occurs.

### 31.3.3.5 Force out logic

For each submodule, the software can select between eight signal sources for the FORCE\_OUT signal depending on the chip architecture:

1. Local CTRL2[FORCE]
2. Master Force signal from submodule0
3. Local Reload signal
4. Master Reload signal from submodule0
5. Local Synchronization signal
6. Master Synchronization signal from submodule0
7. EXT\_SYNC signal from on or off chip
8. EXT\_FORCE signal from on or off chip

The local signals are used to change the signals on the output pins of the submodule without regard for synchronization with other submodules. However, if it is required that all signals on all submodule outputs change at the same time, the Master, EXT\_SYNC, or EXT\_FORCE signals must be selected.

Figure 107 illustrates the Force logic. The SEL23 and SEL45 fields each choose from one of four signals that can be supplied to the submodule outputs: the PWM signal, the inverted PWM signal, a binary level specified by software via the OUT23 and OUT45 bits, or the PWM\_EXTA alternate external control signals. The selection can be determined ahead of time, and when a FORCE\_OUT event occurs, these values are presented to the signal selection mux that immediately switches the requested signal to the output of the mux for further processing downstream.



Figure 107. Force out logic for each submodule

The local CTRL2[FORCE] signal of submodule0 can be broadcast as the Master Force signal to other submodules. This feature allows the CTRL2[FORCE] of submodule0 to synchronously update all of the submodule outputs at the same time. The EXT\_FORCE signal originates from outside the PWM module from a source such as a timer or digital comparators in the Analog-to-Digital Converter.

### 31.3.3.6 Independent or complementary channel operation

Writing a logic one to CTRL2[INDEP] configures the pair of PWM outputs as two independent PWM channels. Each PWM output is controlled by its own VALx pair operating independently of the other output.

Writing a logic zero to CTRL2[INDEP] configures the PWM output as a pair of complementary channels. The PWM pins are paired as shown in Figure 3-16 in complementary channel operation. The signal that is connected to the output pin (PWM23 or PWM45) is determined by MCTRL[IPOL].



Figure 108. Complementary channel pair for each submodule

The complementary channel operation is for driving top and bottom transistors in a motor drive circuit, as shown in [Figure 109](#).



**Figure 109.** Typical 3 phase AC motor drive

The complementary operation allows the use of the deadtime insertion feature.

### 31.3.3.7 Deadtime insertion logic

The following figure shows the deadtime insertion logic of each submodule which is used to create non-overlapping complementary signals when not in independent mode.



**Figure 110.** Deadtime Insertion Logic for each submodule

While in the complementary mode, a PWM pair can be used to drive top/bottom transistors, as shown in the figure. When the top PWM channel is active, the bottom PWM channel is inactive, and vice versa.

**NOTE**

To avoid short-circuiting the DC bus and endangering the transistor, there must be no overlap of conducting intervals between the top and bottom transistors. But the transistor's characteristics make its switching-off time longer than switching-on time. To avoid the conducting overlap of top and bottom transistors, deadtime needs to be inserted in the switching period, as shown in [Figure 111](#).

The deadtime generators automatically insert software-selectable activation delays into the pair of PWM outputs. The deadtime registers (DTCNT0 and DTCNT1) specify the number of IPBus clock cycles to use for deadtime delay. Every time the deadtime generator inputs change state, deadtime is inserted. Deadtime forces both PWM outputs in the pair to the inactive state.

When deadtime is inserted in complementary PWM signals connected to an inverter driving an inductive load, the PWM waveform on the inverter output will have a different duty cycle than what appears on the output pins of the PWM module. This results in a distortion in the voltage applied to the load. A method of correcting this, adding to or subtracting from the PWM value used, is discussed next.



**Figure 111. Deadtime insertion**

### 31.3.3.7.1 Top/Bottom correction

In complementary mode, either the top or the bottom transistor controls the output voltage. However, deadtime has to be inserted to avoid overlap of conducting interval between the top and bottom transistor. Both transistors in complementary mode are off during deadtime, allowing the output voltage to be determined by the current status of load and introducing distortion in the output voltage, as shown in [Figure 112](#). On AC induction motors running open-loop, the distortion typically manifests itself as poor low-speed performance, such as torque ripple and rough operation.



**Figure 112. Deadtime distortion**

During deadtime, load inductance distorts output voltage by keeping current flowing through the diodes. This deadtime current flow creates a load voltage that varies with the current direction. With a positive current flow, the load voltage during deadtime is equal to the bottom supply, putting the top transistor in control. With a negative current flow, the load voltage during deadtime is equal to the top supply putting the bottom transistor in control.

Remembering that the original PWM pulse widths were shortened by deadtime insertion, the averaged sinusoidal output is less than the desired value. However, when deadtime is inserted, it distorts in the motor current waveform inverter outputs. This distortion is aggravated by different turn-on and turn-off delays of each of the transistors. By giving the PWM module information on which transistor is controlling at a given time this distortion can be corrected.

For a typical circuit in complementary channel operation, only one of the transistors is effective in controlling the output voltage at any given time. This depends on the direction of the motor inverter current for that pair, as shown in [Figure 112](#). To correct distortion one of two different factors must be added to the desired PWM value, depending on whether the top or bottom transistor is controlling the output voltage. Therefore, the software is responsible for calculating both compensated PWM values prior to placing them in the VALx registers. Either the VAL2/VAL3 or the VAL4/VAL5 register pair controls the pulse width at any given time. For a given PWM pair, whether the VAL2/VAL3 or VAL4/VAL5 pair is active depends on either:

- The state of the current status pin, PWMX, for that driver
- The state of the odd/even correction bit, MCTRL[IPOL], for that driver

To correct deadtime distortion, the software can decrease or increase the value in the appropriate VALx register.

- In edge-aligned operation, decreasing or increasing the PWM value by a correction value equal to the deadtime typically compensates for deadtime distortion.
- In center-aligned operation, decreasing or increasing the PWM value by a correction value equal to one-half the deadtime typically compensates for deadtime distortion.

### 31.3.3.7.2 Manual correction

To detect the current status, the voltage on each PWMX pin is sampled twice in a PWM period, at the end of each deadtime. The value is stored in CTRL[DT]. CTRL[DT] is a timing marker indicating when to toggle between PWM value registers. The software can then set MCTRL[IPOL] to switch between VAL2/VAL3 and VAL4/VAL5 register pairs according to CTRL[DT] values.



Both D flip-flops latch low,  $\text{CTRL[DT]} = 00$ , during deadtime periods if the current is large and flowing out of the complementary circuit. See the preceding figure. Both D flip-flops latch the high,  $\text{CTRL[DT]} = 11$ , during deadtime periods if the current is also large and flowing into the complementary circuit.

However, under low-current, the output voltage of the complementary circuit during deadtime is between the high and low levels. The current cannot free-wheel through the opposition anti-body diode, regardless of polarity, giving additional distortion when the current crosses zero. Sampled results are  $\text{CTRL[DT]} = b10$ . Thus, the best time to change one PWM value register to another is just before the current zero crossing.



### 31.3.3.8 Output logic

The following figure shows the output logic of each submodule including how each PWM output has individual fault disabling, polarity control, and output enable. This allows for maximum flexibility when interfacing with the external circuitry.

The PWM23 and PWM45 signals which are output from the deadtime logic (as shown in Figure 115) are positive true signals. In other words, a high level on these signals should result in the corresponding transistor in the PWM inverter being turned ON. The voltage level required at the PWM output pin to turn the transistor ON or OFF is a function of the logic between the pin and the transistor. Therefore, it is imperative that the user program OCTRL[POLA] and OCTRL[POLB] before enabling the output pins. A fault condition can result in the PWM output being put in a high-impedance state, forced to a logic 1 state, or forced to a logic 0 state, depending on the values programmed into the OCTRL[PWMxFS] fields.



Figure 115. Output logic for each submodule



### 31.3.3.9 E-Capture

The Enhanced Capture (E-Capture) logic is designed to measure both edges of an input signal. As a result, when a submodule pin is configured for input capture, the CVALx registers associated with that pin are used to record the edge values.

The following figure shows block diagram of the E-Capture circuit. Upon entering the pin input, the signal is split into two paths. One goes straight to a mux input where software can select to pass the signal directly to the capture logic for processing. The other path connects the signal to an 8-bit counter which counts both the rising and falling edges of the signal. The output of this counter is compared to an 8-bit value that is specified by the user (EDGCMPx) and when the two values are equal, the comparator generates a pulse that resets the counter. This pulse is also supplied to the mux input where software can select it to be processed by the capture logic. This feature permits the E-Capture circuit to count up to 256 edge events before initiating a capture event. This feature is useful for dividing down high frequency signals for capture processing so that capture interrupts do not overwhelm the CPU. Also, this feature can be used to generate an interrupt after "n" events have been counted.



Figure 117. Enhanced capture (E-Capture) logic

Based on the mode selection, the mux selects either the pin input or the compare output from the count/compare circuit to be processed by the capture logic. The selected signal is routed to two separate capture circuits which work in tandem to capture sequential edges of the signal. The type of edge to be captured by each circuit is determined by CAPTCTRLx[EDGx1] and CAPTCTRLx[EDGx0], whose functionality is listed in the above figure. Also, controlling the operation of the capture circuits is the arming logic which allows captures to be performed in a free running (continuous) or one shot mode. In free running mode, the capture sequences will be performed indefinitely. If both capture circuits are enabled, they will work together in a ping-pong style where a capture event from one circuit leads to the arming of the other and vice versa. In one shot mode, only one capture sequence will be performed. If both capture circuits are enabled, capture circuit 0 is first armed and when a capture event occurs, capture circuit 1 is armed. Once the second capture occurs, further captures are disabled until another capture sequence is initiated. Both capture circuits are also capable of generating an interrupt to the CPU.

### 31.3.3.10 Fault protection

Fault protection can control any combination of PWM output pins. Faults are generated by a logic one on any of the FAULTx pins. This polarity can be changed via FCTRL[FLVL]. Each FAULTx pin can be mapped arbitrarily to any of the PWM outputs. When fault protection hardware disables PWM outputs, the PWM generator continues to run, only the output pins are forced to logic 0, logic 1, or high impedance depending on the values of OCTRL[PWMxFS].

The fault decoder disables PWM pins selected by the fault logic and the disable mapping (DISMAPn) registers. The following figure shows an example of the fault disable logic. Each bank of bits in DISMAPn control the mapping for a single PWM pin. See the following table.

The fault protection is enabled even when the PWM module is not enabled. Therefore, a fault is latched in and must be cleared to prevent an interrupt when the PWM is enabled.



Figure 118. Fault decoder for PWM\_A

Table 170. Fault Mapping

| PWM Pin for 1 submodule | Controlling Register Bits |
|-------------------------|---------------------------|
| PWM_A                   | DISMAP0[DIS0A]            |
| PWM_B                   | DISMAP0[DIS0B]            |
| PWM_X                   | DISMAP0[DIS0X]            |

### 31.3.3.10.1 Fault pin filter

Each fault pin has a programmable filter that can be bypassed. The sampling period of the filter can be adjusted with FFILT[FILT\_PER]. The number of consecutive samples that must agree before an input transition is recognized can be adjusted using FFILT[FILT\_CNT]. Setting FFILT[FILT\_PER] to all 0 disables the input filter for a given FAULTx pin.

Upon detecting a logic 0 on the filtered FAULTx pin (or a logic 1 if FCTRL[FLVLx] is set), the corresponding FSTS[FFPINx] and FSTS[FFLAGx] bits are set. FSTS[FFPINx] remains set as long as the filtered FAULTx pin is zero. Clear FSTS[FFLAGx] by writing a logic 1 to FSTS[FFLAGx].

If the FIEx, FAULTx pin interrupt enable bit is set, FSTS[FFLAGx] generates a CPU interrupt request. The interrupt request latch remains set until:

- Software clears FSTS[FFLAGx] by writing a logic one to the bit
- Software clears the FIEx bit by writing a logic zero to it
- A reset occurs

Even with the filter enabled, there is a combinational path from the FAULTx inputs to the PWM pins, which in turn bypasses the filter when FCTRL20[NOCOMBx] = 0. This logic is also capable of holding a fault condition in the event of loss of clock to the PWM module.

### 31.3.3.10.2 Automatic fault clearing

Setting an automatic clearing mode bit, FCTRL[FAUTOx] configures faults from the FAULTx pin for automatic clearing.

When FCTRL[FAUTOx] is set, disabled PWM pins are enabled when the FAULTx pin returns to logic one and a new PWM full or half cycle begins. See the following figure. If FSTS[FFULLx] is set and the fault condition on FAULTx disappears, then the disabled PWM pins are enabled at the start of next full cycle. If FSTS[FHALFx] is set, then the disabled PWM pins are enabled at the start of a half cycle. Clearing FSTS[FFLAGx] does not affect disabled PWM pins when FCTRL[FAUTOx] is set.



### 31.3.3.10.3 Manual fault clearing

Clearing the automatic clearing mode bit, FCTRL[FAUTOx], configures faults from the FAULTx pin for manual clearing:

- If the fault safety mode bits FCTRL[FSAFEx] are clear, then PWM pins disabled by the FAULTx pins are enabled when:
  - Software clears the corresponding FSTS[FFLAGx] flag
  - The pins are enabled when the next PWM full or half cycle begins regardless of the logic level detected by the filter at the FAULTx pin, as shown in [Figure 120](#). If FSTS[FFULLx] is set, then the disabled PWM pins are enabled at the start of a full cycle. If FSTS[FHALFx] is set, then the disabled PWM pins are enabled at the start of a half cycle.
- If the fault safety mode bits FCTRL[FSAFEx] are set, then PWM pins disabled by the FAULTx pins are enabled when:
  - Software clears the corresponding FSTS[FFLAGx] flag
  - The filter detects a logic zero on the FAULTx pin at the start of the next PWM full or half cycle boundary, as shown in [Figure 121](#). If FSTS[FFULLx] is set, then the disabled PWM pins are enabled at the start of a full cycle. If FSTS[FHALFx] is set, then the disabled PWM pins are enabled at the start of a half cycle.



Figure 120. Manual fault clearing (FCTRL[FSAFEEx] = 0, FSTS[FFULLx] = 1)



Figure 121. Manual fault clearing (FCTRL[FSAFEEx] = 1, FSTS[FHALFx] = 1)

**NOTE**

Fault protection also applies during software output control when the SEL23 and SEL45 fields are set to select OUT23 and OUT45 bits or PWM\_EXT\_A. Fault clearing still occurs at half or full PWM cycle boundaries while the PWM generator is engaged, MCTRL[RUN] equals one. But the OUTx bits can control the PWM pins while the PWM generator is off, MCTRL[RUN] equals zero. Thus, fault clearing occurs at IPBus cycles while the PWM generator is off and at the start of PWM cycles when the generator is engaged.

### 31.3.3.10.4 Fault testing

FTST[FTTEST] is used to simulate a fault condition on each of the fault inputs within that fault channel.

### 31.3.3.11 PWM generator loading

#### 31.3.3.11.1 Load enable

MCTRL[LDOK] enables loading of the following PWM generator parameters.

- The prescaler divisor: from CTRL[PRSC]
- The PWM period and pulse width: from the INIT, FRACVALx, and VALx registers

MCTRL[LDOK] allows the software to finish calculating all of these PWM parameters so they can be synchronously updated. The CTRL[PRSC], INIT, and VALx registers are loaded by software into a set of outer buffers. When MCTRL[LDOK] is set, these values are transferred to an inner set of registers at the beginning of the next PWM reload cycle to be used by the PWM generator when CTRL[LDMOD] is cleared. These values can be transferred to the inner set of registers immediately upon setting MCTRL[LDOK] if CTRL[LDMOD] is set. Set MCTRL[LDOK] by reading it when it is a logic zero and then writing a logic one to it. After loading, MCTRL[LDOK] is automatically cleared.

### 31.3.3.11.2 Load frequency

CTRL[LDFQ] selects an integral loading frequency of one to 16 PWM reload opportunities. CTRL[LDFQ] takes effect at every PWM reload opportunity, regardless of the state of MCTRL[LDO]. CTRL[HALF] and CTRL[FULL] control reload timing. If CTRL[FULL] is set, a reload opportunity occurs at the end of every PWM cycle when the count equals VAL1. If CTRL[HALF] is set, a reload opportunity occurs at the half cycle when the count equals VAL0. If both CTRL[HALF] and CTRL[FULL] are set, a reload opportunity occurs twice per PWM cycle when the count equals VAL1 and when it equals VAL0.



Figure 122. Full cycle reload frequency change



Figure 123. Half cycle reload frequency change



Figure 124. Full and half cycle reload frequency change

### 31.3.3.11.3 Reload flag

At every reload opportunity the PWM Reload Flag (STS[RF]) is set. Setting STS[RF] happens even if an actual reload is prevented by MCTRL[LDO]. If the PWM reload interrupt enable bit INTEN[RIE] is set, the STS[RF] flag generates CPU interrupt requests allowing software to calculate new PWM parameters in real time. When INTEN[RIE] is not set, reloads still occur at the selected reload rate without generating CPU interrupt requests.



Figure 125. PWMF reload interrupt request

### 31.3.3.11.4 Reload errors

When one of the INIT, VALx, FRACVALx, or CTRL[PRSC] registers is updated (written by software), the STS[RUF] flag is set to indicate the data in the set of double buffered registers is not coherent. STS[RUF] is cleared by a successful reload which consists of the reload signal while MCTRL[LDOK] is set. If STS[RUF] is set and MCTRL[LDOK] is clear when the reload signal occurs, a reload error takes place and STS[REF] is set. If STS[RUF] is clear when a reload signal asserts, then the data is coherent and no error is flagged.

### 31.3.3.11.5 Initialization

Initialize all registers and then set MCTRL[LDOK] before setting MCTRL[RUN].

#### NOTE

If MCTRL[LDOK] is not set, setting MCTRL[RUN] also sets the STS[RF] flag. To prevent a CPU interrupt request, clear INTEN[RIE] before setting MCTRL[RUN].

The PWM generator uses the last values loaded if MCTRL[RUN] is cleared and then set while MCTRL[LDOK] equals zero.

When MCTRL[RUN] is cleared:

- The STS[RF] flag and pending CPU interrupt requests are not cleared
- All fault circuitry remains active
- Software/external output control remains active
- Deadtime insertion continues during software/external output control

### 31.3.4 Power modes

Be careful when using this module in Deep Sleep, Sleep, and Debug operating modes.

#### CAUTION

Some applications require regular software updates for proper operation. Failure to provide regular software updates could result in destroying the hardware setup.

To accommodate this situation, PWM outputs are placed in their inactive states in Deep Sleep mode, and they can optionally be placed in inactive states in Sleep and Debug modes. PWM outputs are reactivated (assuming they were active beforehand) when these modes are exited.

Table 171. Modes when PWM operation is restricted

| Mode       | Description                                                       |
|------------|-------------------------------------------------------------------|
| Deep Sleep | PWM outputs are inactive.                                         |
| Debug      | PWM outputs are driven or inactive as a function of CTRL2[DBGEN]. |

### 31.3.5 Clocking

Figure 126 shows the logic used to generate the main counter clock. Each submodule can select between three clock signals: the IPBus clock, EXT\_CLK, and AUX\_CLK. The EXT\_CLK goes to all of the submodules. The AUX\_CLK signal is broadcast from submodule0 and can be selected as the clock source by other submodules so that the 8-bit prescaler and MCTRL[RUN] from submodule0 can control all of the submodules.



Figure 126. Clocking Block Diagram for PWM Submodule 0



Figure 127. Clocking Block Diagram for all other PWM Submodules

To permit lower PWM frequencies, the prescaler produces the PWM clock frequency by dividing the IPBus clock frequency by 1-128. The prescaler bits, CTRL[PRSC], select the prescaler divisor. This prescaler is buffered and will not be used by the PWM generator until MCTRL[LDOKE] is set and a new PWM reload cycle begins or CTRL[LDMOD] is set.

### 31.3.6 Resets

All PWM registers are reset to their default values upon any system reset.

The reset forces all registers to their reset states and tristates the PWM outputs.

### 31.3.7 Interrupts

Each of the submodules within the eFlexPWM module can generate an interrupt from several sources. The fault logic can also generate interrupts. The interrupt service routine (ISR) must check the related interrupt enables and interrupt flags to determine the actual cause of the interrupt.

Table 172. Interrupt Summary

| Core Interrupt | Interrupt Flag                | Interrupt Enable                      | Name                                | Description                       |
|----------------|-------------------------------|---------------------------------------|-------------------------------------|-----------------------------------|
| PWM_CMP0       | SM0STS[CMF]                   | SM0INTEN[CMPIE]                       | Submodule 0 compare interrupt       | Compare event has occurred        |
| PWM_CAP0       | SM0STS[CFX1],<br>SM0STS[CFX0] | SM0INTEN[CFX1IE],<br>SM0INTEN[CFX0IE] | Submodule 0 input capture interrupt | Input capture event has occurred  |
| PWM_RELOAD0    | SM0STS[RF]                    | SM0INTEN[RIE]                         | Submodule 0 reload interrupt        | Reload event has occurred         |
| PWM_CMP1       | SM1STS[CMF]                   | SM1INTEN[CMPIE]                       | Submodule 1 compare interrupt       | Compare event has occurred        |
| PWM_CAP1       | SM1STS[CFX1],<br>SM1STS[CFX0] | SM1INTEN[CFX1IE],<br>SM1INTEN[CFX0IE] | Submodule 1 input capture interrupt | Input capture event has occurred  |
| PWM_RELOAD1    | SM1STS[RF]                    | SM1INTEN[RIE]                         | Submodule 1 reload interrupt        | Reload event has occurred         |
| PWM_CMP2       | SM2STS[CMF]                   | SM2INTEN[CMPIE]                       | Submodule 2 compare interrupt       | Compare event has occurred        |
| PWM_CAP2       | SM2STS[CFX1],<br>SM2STS[CFX0] | SM2INTEN[CFX1IE],<br>SM2INTEN[CFX0IE] | Submodule 2 input capture interrupt | Input capture event has occurred  |
| PWM_RELOAD2    | SM2STS[RF]                    | SM2INTEN[RIE]                         | Submodule 2 reload interrupt        | Reload event has occurred         |
| PWM_RERR       | SM0STS[REF]                   | SM0INTEN[REIE]                        | Submodule 0 reload error interrupt  | Reload error has occurred         |
|                | SM1STS[REF]                   | SM1INTEN[REIE]                        | Submodule 1 reload error interrupt  |                                   |
|                | SM2STS[REF]                   | SM2INTEN[REIE]                        | Submodule 2 reload error interrupt  |                                   |
| PWM_FAULT      | FSTS[FFLAG]                   | FCTRL[FIE]                            | Fault input interrupt               | Fault condition has been detected |

### 31.3.8 DMA

Each submodule can request a DMA read access for its capture FIFOs and a DMA write request for its double buffered registers.

Table 173. DMA summary

| DMA request              | DMA enable      | Name                             | Description                          |
|--------------------------|-----------------|----------------------------------|--------------------------------------|
| Submodule 0 read request | SM0DMAEN[CX0DE] | SM0 Capture FIFO X0 read request | SM0CVAL0 contains a value to be read |

*Table continues on the next page...*

Table 173. DMA summary (continued)

| DMA request               | DMA enable       | Name                                        | Description                                          |
|---------------------------|------------------|---------------------------------------------|------------------------------------------------------|
| Submodule 0 read request  | SM0DMAEN[CX1DE]  | SM0 Capture FIFO X1 read request            | SM0CVAL1 contains a value to be read                 |
| Submodule 0 read request  | SM0DMAEN[CAPTDE] | SM0 Capture FIFO read request source select | Selects source of submodule0 read DMA request        |
| Submodule 0 write request | SM0DMAEN[VALDE]  | SM0VALx write request                       | SM0VALx and SM0FRACVALx registers need to be updated |
| Submodule 1 read request  | SM1DMAEN[CX0DE]  | SM1 Capture FIFO X0 read request            | SM1CVAL0 contains a value to be read                 |
| Submodule 1 read request  | SM1DMAEN[CX1DE]  | SM1 Capture FIFO X1 read request            | SM1CVAL1 contains a value to be read                 |
| Submodule 1 read request  | SM1DMAEN[CAPTDE] | SM1 Capture FIFO read request source select | Selects source of submodule1 read DMA request        |
| Submodule 1 write request | SM1DMAEN[VALDE]  | SM1VALx write request                       | SM1VALx and SM1FRACVALx registers need to be updated |
| Submodule 2 read request  | SM2DMAEN[CX0DE]  | SM2 Capture FIFO X0 read request            | SM2CVAL0 contains a value to be read                 |
| Submodule 2 read request  | SM2DMAEN[CX1DE]  | SM2 Capture FIFO X1 read request            | SM2CVAL1 contains a value to be read                 |
| Submodule 2 read request  | SM2DMAEN[CAPTDE] | SM2 Capture FIFO read request source select | Selects source of submodule2 read DMA request        |
| Submodule 2 write request | SM2DMAEN[VALDE]  | SM2VALx write request                       | SM2VALx and SM2FRACVALx registers need to be updated |

### 31.4 External signals

The PWM has pins named PWM\_An, PWM\_Bn, PWM\_Xn, FAULTn, EXT\_SYNC, EXT\_FORCE, and PWMn\_EXTA. The PWM also has an on-chip input called EXT\_CLK and output signals called PWMn\_OUT\_TRIGx and PWMn\_MUX\_TRIGx.

#### 31.4.1 PWM\_An and PWM\_Bn - External PWM output pair

These pins are the output pins of the PWM channels. These pins can be independent PWM signals or a complementary pair. When not needed as an output, they can be used as inputs to the input capture circuitry.

#### 31.4.2 PWM\_Xn - Auxiliary PWM output signal

These pins are the auxiliary output pins of the PWM channels. They can be independent PWM signals. When not needed as an output, they can be used as inputs to the input capture circuitry or used to detect the polarity of the current flowing through the complementary circuit at deadtime correction.

#### 31.4.3 FAULTn - Fault Inputs

These are input pins for disabling selected PWM outputs.

### 31.4.4 EXT\_SYNC - External synchronization signal

These input signals allow a source external to the PWM to initialize the PWM counter. Therefore, the PWM can be synchronized to external circuitry.

### 31.4.5 EXT\_FORCE - External output force signal

This input signal allows a source external to the PWM to force an update of the PWM outputs. Therefore, the PWM can be synchronized to external circuitry.

### 31.4.6 PWM<sub>n</sub>\_EXTA - Alternate PWM control signals

These pins allow an alternate source to control the PWM\_An and PWM\_Bn outputs. Typically, the PWM<sub>n</sub>\_EXTA input (depending on the state of MCTRL[IPOL]) is used for the generation of a complementary pair. Typical control signals include ADC conversion high/low limits, TMR outputs, GPIO inputs, and comparator outputs.

For pin input details, see chip-specific eFlexPWM information.

### 31.4.7 PWM<sub>n</sub>\_OUT\_TRIG0 and PWM<sub>n</sub>\_OUT\_TRIG1 - Output triggers

These outputs allow the PWM submodules to control timing of ADC conversions. See the description of the [SMnTCTRL\[OUT\\_TRIG\\_EN\]](#) for information about how to enable these outputs and how the compare registers match up to the output triggers.

### 31.4.8 PWM[n]\_MUX\_TRIG0 and PWM[n]\_MUX\_TRIG1 - Output triggers

These outputs can be either PWM<sub>n</sub>\_OUT\_TRIG0/PWM<sub>n</sub>\_OUT\_TRIG1 signals or PWM\_A/PWM\_B signals from output logic. See the description of the PWAOT0 and PWBOT1 bits in the Output Trigger Control Register for information about how to enable these outputs.

### 31.4.9 EXT\_CLK - External clock signal

This signal allows a source external to the PWM (typically a timer or an off-chip source) to control the PWM clocking. Therefore, the PWM can be synchronized to the timer, or multiple chips can be synchronized to each other.

## 31.5 PWM register descriptions

The address of a register is the sum of a base address and an address offset. The base address is defined at the core level, and the address offset is defined at the module level. The PWM module has a set of registers for each PWM submodule, for the configuration logic, and for each fault channel.

#### NOTE

While the registers are 16-bit wide, they can be accessed in pairs as 32-bit registers, if the pairs are word-aligned.

Submodule registers are repeated for each PWM submodule. To designate which submodule that they are in, register names are prefixed with SMx(x=0,1...). The base address of submodule 0 is the same as the base address for the PWM module as a whole. The base address of submodule 1 is offset 0x60 from the base address for the PWM module as a whole. This 0x60 offset is based on the number of registers in a submodule. The base address of submodule 2 is equal to the base address of submodule 1 plus this same 0x60 offset.

The base address of the configuration registers is equal to the base address of the PWM module as a whole plus an offset of 0x180.

### 31.5.1 PWM memory map

FlexPWM0 base address: 400A\_9000h

| Offset | Register                                                        | Width<br>(In bits) | Access | Reset value |
|--------|-----------------------------------------------------------------|--------------------|--------|-------------|
| 0h     | Counter Register (SM0CNT)                                       | 16                 | R      | 0000h       |
| 2h     | Initial Count Register (SM0INIT)                                | 16                 | RW     | 0000h       |
| 4h     | Control 2 Register (SM0CTRL2)                                   | 16                 | RW     | 0000h       |
| 6h     | Control Register (SM0CTRL)                                      | 16                 | RW     | 0400h       |
| Ah     | Value Register 0 (SM0VAL0)                                      | 16                 | RW     | 0000h       |
| Eh     | Value Register 1 (SM0VAL1)                                      | 16                 | RW     | 0000h       |
| 12h    | Value Register 2 (SM0VAL2)                                      | 16                 | RW     | 0000h       |
| 16h    | Value Register 3 (SM0VAL3)                                      | 16                 | RW     | 0000h       |
| 1Ah    | Value Register 4 (SM0VAL4)                                      | 16                 | RW     | 0000h       |
| 1Eh    | Value Register 5 (SM0VAL5)                                      | 16                 | RW     | 0000h       |
| 22h    | Output Control Register (SM0OCTRL)                              | 16                 | RW     | 0000h       |
| 24h    | Status Register (SM0STS)                                        | 16                 | RW     | 0000h       |
| 26h    | Interrupt Enable Register (SM0INTEN)                            | 16                 | RW     | 0000h       |
| 28h    | DMA Enable Register (SM0DMAEN)                                  | 16                 | RW     | 0000h       |
| 2Ah    | Output Trigger Control Register (SM0TCTRL)                      | 16                 | RW     | 0000h       |
| 2Ch    | Fault Disable Mapping Register 0 (SM0DISMAP0)                   | 16                 | RW     | FFFFh       |
| 30h    | Deadtime Count Register 0 (SM0DTCNT0)                           | 16                 | RW     | 07FFh       |
| 32h    | Deadtime Count Register 1 (SM0DTCNT1)                           | 16                 | RW     | 07FFh       |
| 3Ch    | Capture Control X Register (SM0CAPTCTRLX)                       | 16                 | RW     | 0000h       |
| 3Eh    | Capture Compare X Register (SM0CAPTCOMPX)                       | 16                 | RW     | 0000h       |
| 40h    | Capture Value 0 Register (SM0CVAL0)                             | 16                 | R      | 0000h       |
| 42h    | Capture Value 0 Cycle Register (SM0CVAL0CYC)                    | 16                 | R      | 0000h       |
| 44h    | Capture Value 1 Register (SM0CVAL1)                             | 16                 | R      | 0000h       |
| 46h    | Capture Value 1 Cycle Register (SM0CVAL1CYC)                    | 16                 | R      | 0000h       |
| 5Eh    | Capture PWM_X Input Filter Register (SM0CAPTFILT <sub>X</sub> ) | 16                 | RW     | 0000h       |
| 60h    | Counter Register (SM1CNT)                                       | 16                 | R      | 0000h       |
| 62h    | Initial Count Register (SM1INIT)                                | 16                 | RW     | 0000h       |
| 64h    | Control 2 Register (SM1CTRL2)                                   | 16                 | RW     | 0000h       |
| 66h    | Control Register (SM1CTRL)                                      | 16                 | RW     | 0400h       |
| 6Ah    | Value Register 0 (SM1VAL0)                                      | 16                 | RW     | 0000h       |
| 6Eh    | Value Register 1 (SM1VAL1)                                      | 16                 | RW     | 0000h       |
| 72h    | Value Register 2 (SM1VAL2)                                      | 16                 | RW     | 0000h       |

Table continues on the next page...

*Table continued from the previous page...*

| Offset | Register                                           | Width<br>(In bits) | Access | Reset value |
|--------|----------------------------------------------------|--------------------|--------|-------------|
| 76h    | Value Register 3 (SM1VAL3)                         | 16                 | RW     | 0000h       |
| 7Ah    | Value Register 4 (SM1VAL4)                         | 16                 | RW     | 0000h       |
| 7Eh    | Value Register 5 (SM1VAL5)                         | 16                 | RW     | 0000h       |
| 82h    | Output Control Register (SM1OCTRL)                 | 16                 | RW     | 0000h       |
| 84h    | Status Register (SM1STS)                           | 16                 | RW     | 0000h       |
| 86h    | Interrupt Enable Register (SM1INTEN)               | 16                 | RW     | 0000h       |
| 88h    | DMA Enable Register (SM1DMAEN)                     | 16                 | RW     | 0000h       |
| 8Ah    | Output Trigger Control Register (SM1TCTRL)         | 16                 | RW     | 0000h       |
| 8Ch    | Fault Disable Mapping Register 0 (SM1DISMAP0)      | 16                 | RW     | FFFFh       |
| 90h    | Deadtime Count Register 0 (SM1DTCNT0)              | 16                 | RW     | 07FFh       |
| 92h    | Deadtime Count Register 1 (SM1DTCNT1)              | 16                 | RW     | 07FFh       |
| 9Ch    | Capture Control X Register (SM1CAPTCTRLX)          | 16                 | RW     | 0000h       |
| 9Eh    | Capture Compare X Register (SM1CAPTCOMPX)          | 16                 | RW     | 0000h       |
| A0h    | Capture Value 0 Register (SM1CVAL0)                | 16                 | R      | 0000h       |
| A2h    | Capture Value 0 Cycle Register (SM1CVAL0CYC)       | 16                 | R      | 0000h       |
| A4h    | Capture Value 1 Register (SM1CVAL1)                | 16                 | R      | 0000h       |
| A6h    | Capture Value 1 Cycle Register (SM1CVAL1CYC)       | 16                 | R      | 0000h       |
| B8h    | Phase Delay Register (SM1PHASEDLY)                 | 16                 | RW     | 0000h       |
| BEh    | Capture PWM_X Input Filter Register (SM1CAPTFILTX) | 16                 | RW     | 0000h       |
| C0h    | Counter Register (SM2CNT)                          | 16                 | R      | 0000h       |
| C2h    | Initial Count Register (SM2INIT)                   | 16                 | RW     | 0000h       |
| C4h    | Control 2 Register (SM2CTRL2)                      | 16                 | RW     | 0000h       |
| C6h    | Control Register (SM2CTRL)                         | 16                 | RW     | 0400h       |
| CAh    | Value Register 0 (SM2VAL0)                         | 16                 | RW     | 0000h       |
| CEh    | Value Register 1 (SM2VAL1)                         | 16                 | RW     | 0000h       |
| D2h    | Value Register 2 (SM2VAL2)                         | 16                 | RW     | 0000h       |
| D6h    | Value Register 3 (SM2VAL3)                         | 16                 | RW     | 0000h       |
| DAh    | Value Register 4 (SM2VAL4)                         | 16                 | RW     | 0000h       |
| DEh    | Value Register 5 (SM2VAL5)                         | 16                 | RW     | 0000h       |
| E2h    | Output Control Register (SM2OCTRL)                 | 16                 | RW     | 0000h       |
| E4h    | Status Register (SM2STS)                           | 16                 | RW     | 0000h       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset          | Register                                           | Width<br>(In bits) | Access | Reset value |
|-----------------|----------------------------------------------------|--------------------|--------|-------------|
| E6h             | Interrupt Enable Register (SM2INTEN)               | 16                 | RW     | 0000h       |
| E8h             | DMA Enable Register (SM2DMAEN)                     | 16                 | RW     | 0000h       |
| EAh             | Output Trigger Control Register (SM2TCTRL)         | 16                 | RW     | 0000h       |
| EC <sub>h</sub> | Fault Disable Mapping Register 0 (SM2DISMAP0)      | 16                 | RW     | FFFFh       |
| F0h             | Deadtime Count Register 0 (SM2DTCNT0)              | 16                 | RW     | 07FFh       |
| F2h             | Deadtime Count Register 1 (SM2DTCNT1)              | 16                 | RW     | 07FFh       |
| FCh             | Capture Control X Register (SM2CAPTCTRLX)          | 16                 | RW     | 0000h       |
| FEh             | Capture Compare X Register (SM2CAPTCOMPX)          | 16                 | RW     | 0000h       |
| 100h            | Capture Value 0 Register (SM2CVAL0)                | 16                 | R      | 0000h       |
| 102h            | Capture Value 0 Cycle Register (SM2CVAL0CYC)       | 16                 | R      | 0000h       |
| 104h            | Capture Value 1 Register (SM2CVAL1)                | 16                 | R      | 0000h       |
| 106h            | Capture Value 1 Cycle Register (SM2CVAL1CYC)       | 16                 | R      | 0000h       |
| 118h            | Phase Delay Register (SM2PHASEDLY)                 | 16                 | RW     | 0000h       |
| 11Eh            | Capture PWM_X Input Filter Register (SM2CAPTFILTX) | 16                 | RW     | 0000h       |
| 180h            | Output Enable Register (OUTEN)                     | 16                 | RW     | 0000h       |
| 182h            | Mask Register (MASK)                               | 16                 | RW     | 0000h       |
| 184h            | Software Controlled Output Register (SWCOUT)       | 16                 | RW     | 0000h       |
| 186h            | PWM Source Select Register (DTSRCSEL)              | 16                 | RW     | 0000h       |
| 188h            | Master Control Register (MCTRL)                    | 16                 | RW     | 0000h       |
| 18Ah            | Master Control 2 Register (MCTRL2)                 | 16                 | RW     | 0000h       |
| 18Ch            | Fault Control Register (FCTRL0)                    | 16                 | RW     | 0000h       |
| 18Eh            | Fault Status Register (FSTS0)                      | 16                 | RW     | See section |
| 190h            | Fault Filter Register (FFILT0)                     | 16                 | RW     | 0000h       |
| 192h            | Fault Test Register (FTST0)                        | 16                 | RW     | 0000h       |
| 194h            | Fault Control 2 Register (FCTRL20)                 | 16                 | RW     | 0000h       |

### 31.5.2 Counter Register (SM0CNT - SM2CNT)

Offset

| Register | Offset |
|----------|--------|
| SM0CNT   | 0h     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Register | Offset |
|----------|--------|
| SM1CNT   | 60h    |
| SM2CNT   | C0h    |

### Function

This field displays the state of the signed 16-bit submodule counter. This register is not byte accessible. Writing this register generates bus transfer error.

### Diagram



### Fields

| Field | Function              |
|-------|-----------------------|
| 15-0  | Counter Register Bits |
| CNT   |                       |

### 31.5.3 Initial Count Register (SM0INIT - SM2INIT)

#### Offset

| Register | Offset |
|----------|--------|
| SM0INIT  | 2h     |
| SM1INIT  | 62h    |
| SM2INIT  | C2h    |

#### Function

The 16-bit signed value in this buffered register defines the initial count value for the PWM in PWM clock periods. This is the value loaded into the submodule counter when local sync, master sync, or master reload is asserted (based on the value of CTRL2[INIT\_SEL]) or when CTRL2[FORCE] is asserted and force init is enabled. For PWM operation, the buffered contents of this register are loaded into the counter at the start of every PWM cycle. This register is not byte accessible.

#### NOTE

The INIT register is buffered. The value written does not take effect until MCTRL[LDOCK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. This register cannot be written when MCTRL[LDOCK] is set. Reading INIT reads the value in a buffer and not necessarily the value the PWM generator is currently using.

**Diagram****Fields**

| Field | Function                    |
|-------|-----------------------------|
| 15-0  | Initial Count Register Bits |
| INIT  |                             |

**31.5.4 Control 2 Register (SM0CTRL2 - SM2CTRL2)****Offset**

| Register | Offset |
|----------|--------|
| SM0CTRL2 | 4h     |
| SM1CTRL2 | 64h    |
| SM2CTRL2 | C4h    |

**Function**

Contains control fields for clock select and forcing output and initialization. This register is write-protected by MCTRL2[WRPROT] bits.

**Diagram****Fields**

| Field       | Function                                                                                                                                                                                                                                                                                        |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>DBGEN | Debug Enable<br>When set to one, the PWM continues to run while the chip is in Debug mode. If the device enters Debug mode and this bit is zero, then the PWM outputs are disabled until Debug mode is exited. At that point, the PWM pins resume operation as programmed in the PWM registers. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14<br>—          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 13<br>INDEP      | Independent or Complementary Pair Operation<br><br>This bit determines if the PWM_A and PWM_B channels are independent PWMs or a complementary PWM pair.<br><br>0b - PWM_A and PWM_B form a complementary PWM pair.<br>1b - PWM_A and PWM_B outputs are independent PWMs.                                                                                                                                                                                                                                                                                                                                           |
| 12<br>PWM23_INIT | PWM23 Initial Value<br><br>This bit determines the initial value for PWM23 and the value to which it is forced when FORCE_INIT is asserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11<br>PWM45_INIT | PWM45 Initial Value<br><br>This bit determines the initial value for PWM45 and the value to which it is forced when FORCE_INIT is asserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 10<br>PWMX_INIT  | PWM_X Initial Value<br><br>This bit determines the initial value for PWM_X and the value to which it is forced when FORCE_INIT is asserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 9-8<br>INIT_SEL  | Initialization Control Select<br><br>These bits control the source of the INIT signal which goes to the counter.<br><br>00b - Local sync (PWM_X) causes initialization.<br><br>01b - Master reload from submodule 0 causes initialization. This setting should not be used in submodule 0 as it forces the INIT signal to logic 0. The submodule counter will only re-initialize when a master reload occurs.<br><br>10b - Master sync from submodule 0 causes initialization. This setting should not be used in submodule 0 as it forces the INIT signal to logic 0.<br><br>11b - EXT_SYNC causes initialization. |
| 7<br>FRCEN       | Force Enable<br><br>This bit allows the CTRL2[FORCE] signal to initialize the counter without regard to the signal selected by CTRL2[INIT_SEL]. This is a software controlled initialization. A forced initialization will also assert the register reload if MCTRL[LDOCK] is set.<br><br>0b - Initialization from a FORCE_OUT is disabled.<br>1b - Initialization from a FORCE_OUT is enabled.                                                                                                                                                                                                                     |
| 6<br>FORCE       | Force Initialization<br><br>If CTRL2[FORCE_SEL] is set to 000, writing a 1 to this bit results in a FORCE_OUT event. This causes the following actions to be taken:                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <ul style="list-style-type: none"> <li>The PWM_A and PWM_B output pins assume values based on DTSRCSEL[SMxSEL23] and DTSRCSEL[SMxSEL45].</li> <li>If CTRL2[FRCEN] is set, the counter value is initialized with the INIT register value only when the submodule MCTRL[RUN] = 1 or CTRL2[CLK_SEL] = 2.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 5-3<br>FORCE_SEL | <p>Force Select</p> <p>This bit determines the source of the FORCE OUTPUT signal for this submodule.</p> <p>000b - The local force signal, CTRL2[FORCE], from this submodule is used to force updates.</p> <p>001b - The master force signal from submodule 0 is used to force updates. This setting should not be used in submodule 0 as it holds the FORCE OUTPUT signal to logic 0.</p> <p>010b - The local reload signal from this submodule is used to force updates without regard to the state of LDOCK.</p> <p>011b - The master reload signal from submodule 0 is used to force updates if LDOCK is set. This setting should not be used in submodule 0 as it holds the FORCE OUTPUT signal to logic 0.</p> <p>100b - The local sync signal from this submodule is used to force updates.</p> <p>101b - The master sync signal from submodule 0 is used to force updates. This setting should not be used in submodule 0 as it holds the FORCE OUTPUT signal to logic 0.</p> <p>110b - The external force signal, EXT_FORCE, from outside the PWM module causes updates.</p> <p>111b - The external sync signal, EXT_SYNC, from outside the PWM module causes updates.</p> |
| 2<br>RELOAD_SEL  | <p>Reload Source Select</p> <p>This bit determines the source of the RELOAD signal for this submodule. When this bit is set, MCTRL[LDOCK[0]] for submodule 0 should be used since the local MCTRL[LDOCK] will be ignored.</p> <p>0b - The local RELOAD signal is used to reload registers.</p> <p>1b - The master RELOAD signal (from submodule 0) is used to reload registers. This setting should not be used in submodule 0 as it forces the RELOAD signal to logic 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1-0<br>CLK_SEL   | <p>Clock Source Select</p> <p>These bits determine the source of the clock signal for this submodule.</p> <p>00b - The IPBus clock is used as the clock for the local prescaler and counter.</p> <p>01b - EXT_CLK is used as the clock for the local prescaler and counter.</p> <p>10b - Submodule 0's clock (AUX_CLK) is used as the source clock for the local prescaler and counter. This setting should not be used in submodule 0 as it forces the clock to logic 0.</p> <p>11b - Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

### 31.5.5 Control Register (SM0CTRL - SM2CTRL)

#### Offset

| Register | Offset |
|----------|--------|
| SM0CTRL  | 6h     |
| SM1CTRL  | 66h    |
| SM2CTRL  | C6h    |

#### Function

Includes control settings for timing, loading, and buffering.

#### Diagram



#### Fields

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12<br>LDFQ | <p>Load Frequency</p> <p>These buffered bits select the PWM load frequency. Reset clears LDFQ, selecting loading every PWM opportunity. A PWM opportunity is determined by HALF and FULL. The register bits are write-protected by MCTRL2[WRPROT] bits.</p> <p><b>NOTE</b></p> <p>LDFQ takes effect when the current load cycle is complete, regardless of the state of MCTRL[LDOK]. Reading LDFQ reads the buffered values and not necessarily the values currently in effect.</p> <ul style="list-style-type: none"> <li>0000b - Every PWM opportunity</li> <li>0001b - Every 2 PWM opportunities</li> <li>0010b - Every 3 PWM opportunities</li> <li>0011b - Every 4 PWM opportunities</li> <li>0100b - Every 5 PWM opportunities</li> <li>0101b - Every 6 PWM opportunities</li> <li>0110b - Every 7 PWM opportunities</li> <li>0111b - Every 8 PWM opportunities</li> <li>1000b - Every 9 PWM opportunities</li> </ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | 1001b - Every 10 PWM opportunities<br>1010b - Every 11 PWM opportunities<br>1011b - Every 12 PWM opportunities<br>1100b - Every 13 PWM opportunities<br>1101b - Every 14 PWM opportunities<br>1110b - Every 15 PWM opportunities<br>1111b - Every 16 PWM opportunities                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 11<br>HALF    | <b>Half Cycle Reload</b><br>This bit enables half-cycle reloads. A half cycle is defined by when the submodule counter matches the VAL0 register and does not have to be halfway through the PWM cycle. This bit is write-protected by MCTRL2[WRPROT] bits.<br>0b - Half-cycle reloads disabled.<br>1b - Half-cycle reloads enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 10<br>FULL    | <b>Full Cycle Reload</b><br>This bit enables full-cycle reloads. A full cycle is defined by when the submodule counter matches the VAL1 register. Either CTRL[HALF] or CTRL[FULL] must be set to move the buffered data into the registers used by the PWM generators or CTRL[LDMOD] must be set. If both CTRL[HALF] and CTRL[FULL] are set, then reloads can occur twice per cycle. This bit is write-protected by MCTRL2[WRPROT] bits.<br>0b - Full-cycle reloads disabled.<br>1b - Full-cycle reloads enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 9-8<br>DT     | <b>Deadtime</b><br>These bits reflect the sampled values of the PWM_X input at the end of each deadtime. Sampling occurs at the end of deadtime 0 for DT[0] and the end of deadtime 1 for DT[1]. Reset clears these bits. The register bits are write-protected by MCTRL2[WRPROT] bits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 7<br>COMPMODE | <b>Compare Mode</b><br>This bit controls how comparisons are made between the VAL* registers and the PWM submodule counter. This bit can be written one time after which it requires a reset to release the bit for writing again.<br>0b - The VAL* registers and the PWM counter are compared using an "equal to" method. This means that PWM edges are only produced when the counter is equal to one of the VAL* register values. This implies that a PWM_A output that is high at the end of a period maintains this state until a match with VAL3 clears the output in the following period.<br>1b - The VAL* registers and the PWM counter are compared using an "equal to or greater than" method. This means that PWM edges are produced when the counter is equal to or greater than one of the VAL* register values. This implies that a PWM_A output that is high at the end of a period could go low at the start of the next period if the starting counter value is greater than (but not necessarily equal to) the new VAL3 value. |
| 6-4           | Prescaler                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PRSC       | <p>These buffered bits select the divide ratio of the PWM clock frequency selected by CTRL2[CLK_SEL].</p> <p><b>NOTE</b></p> <p>Reading CTRL[PRSC] reads the buffered values and not necessarily the values currently in effect. CTRL[PRSC] takes effect at the beginning of the next PWM cycle and only when the load okay bit MCTRL[LDOK] is set, or CTRL[LDMOD] is set. This field cannot be written when MCTRL[LDOK] is set.</p> <p>000b - Prescaler 1. PWM clock frequency = <math>f_{clk}</math><br/>     001b - Prescaler 2. PWM clock frequency = <math>f_{clk}/2</math><br/>     010b - Prescaler 4. PWM clock frequency = <math>f_{clk}/4</math><br/>     011b - Prescaler 8. PWM clock frequency = <math>f_{clk}/8</math><br/>     100b - Prescaler 16. PWM clock frequency = <math>f_{clk}/16</math><br/>     101b - Prescaler 32. PWM clock frequency = <math>f_{clk}/32</math><br/>     110b - Prescaler 64. PWM clock frequency = <math>f_{clk}/64</math><br/>     111b - Prescaler 128. PWM clock frequency = <math>f_{clk}/128</math></p> |
| 3<br>SPLIT | <p>Split the DBLPWM signal to PWM_A and PWM_B</p> <p>This bit is used in independent mode when DBLEN is set. This bit allows the two PWM pulses generated by DBLEN to be split with one pulse on PWM_A and one on PWM_B. The two pulses within the same PWM period are created by an XOR function of the PWM_A and PWM_B sources. The splitting function causes PWM_A to output the pulse that occurs when the PWM_A source is 1 and the PWM_B source is 0. The PWM_B output occurs when the PWM_B source is 1 and the PWM_A source is 0. (See <a href="#">Double switching PWMs</a>.) This bit is write-protected by MCTRL2[WRPROT] bits.</p> <p>0b - DBLPWM is not split. PWM_A and PWM_B each have double pulses.<br/>     1b - DBLPWM is split to PWM_A and PWM_B.</p>                                                                                                                                                                                                                                                                                 |
| 2<br>LDMOD | <p>Load Mode Select</p> <p>This bit selects the timing of loading the buffered registers for this submodule. This bit is write-protected by MCTRL2[WRPROT] bits.</p> <p>0b - Buffered registers of this submodule are loaded and take effect at the next PWM reload if MCTRL[LDOK] is set.<br/>     1b - Buffered registers of this submodule are loaded and take effect immediately upon MCTRL[LDOK] being set. In this case, it is not necessary to set CTRL[FULL] or CTRL[HALF].</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1<br>DBLX  | <p>PWM_X Double Switching Enable</p> <p>This bit enables the double switching behavior on PWM_X. When this bit is set, the PWM_X output shall be the exclusive OR combination of PWM_A and PWM_B prior to polarity and masking considerations. This bit is write-protected by MCTRL2[WRPROT] bits.</p> <p>0b - PWM_X double pulse disabled.<br/>     1b - PWM_X double pulse enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                     |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>DBLEN | Double Switching Enable<br><br>This bit enables the double switching PWM behavior (See <a href="#">Double switching PWMs</a> ). This bit is write-protected by MCTRL2[WRPROT] bits.<br><br>0b - Double switching disabled.<br>1b - Double switching enabled. |

### 31.5.6 Value Register 0 (SM0VAL0 - SM2VAL0)

#### Offset

| Register | Offset |
|----------|--------|
| SM0VAL0  | Ah     |
| SM1VAL0  | 6Ah    |
| SM2VAL0  | CAh    |

#### Function

##### NOTE

The VAL0 register is buffered. The value written does not take effect until MCTRL[LDOCK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. VAL0 cannot be written when MCTRL[LDOCK] is set. Reading VAL0 reads the value in a buffer. It is not necessarily the value that the PWM generator is currently using.

#### Diagram



#### Fields

| Field        | Function                                                                                                                                                                                                                                                                                                                                               |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0<br>VAL0 | Value 0<br><br>The 16-bit signed value in this buffered register defines the mid-cycle reload point for the PWM in PWM clock periods. This value also defines when the PWM_X signal is set and the local sync signal is reset. This register is not byte accessible.<br><br><b>NOTE</b><br>The actual behavior takes effect when counter equal VAL0+1. |

### 31.5.7 Value Register 1 (SM0VAL1 - SM2VAL1)

#### Offset

| Register | Offset |
|----------|--------|
| SM0VAL1  | Eh     |
| SM1VAL1  | 6Eh    |
| SM2VAL1  | CEh    |

#### Function

##### NOTE

The VAL1 register is buffered. The value written does not take effect until MCTRL[LDOK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. VAL1 cannot be written when MCTRL[LDOK] is set. Reading VAL1 reads the value in a buffer. It is not necessarily the value that the PWM generator is currently using.

When using FRACVAL1, limit the maximum value of VAL1 to 0xFFFF for unsigned applications or to 0x7FFE for signed applications, to avoid counter rollovers caused by accumulating the fractional period defined by FRACVAL1.

If the VAL1 register defines the timer period (Local Sync is selected as the counter initialization signal), a 100% duty cycle cannot be achieved on the PWM\_X output. After the count reaches VAL1, the PWM\_X output is low for a minimum of one count every cycle. When the Master Sync signal (only originated by the Local Sync from submodule 0) is used to control the timer period, the VAL1 register can be free for other functions such as PWM generation without the duty cycle limitation.

#### Diagram



#### Fields

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0<br>VAL1 | <p>Value 1</p> <p>The 16-bit signed value written to this buffered register defines the modulo count value (maximum count) for the submodule counter. When reaching this count value, the counter reloads itself with the contents of the INIT register and asserts the local sync signal while resetting PWM_X. This register is not byte accessible.</p> <p><b>NOTE</b><br/>The actual behavior takes effect when the counter equals VAL1+1.</p> |

### 31.5.8 Value Register 2 (SM0VAL2 - SM2VAL2)

#### Offset

| Register | Offset |
|----------|--------|
| SM0VAL2  | 12h    |
| SM1VAL2  | 72h    |
| SM2VAL2  | D2h    |

#### Function

**NOTE**

The VAL2 register is buffered. The value written does not take effect until MCTRL[LDOK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. VAL2 cannot be written when MCTRL[LDOK] is set. Reading VAL2 reads the value in a buffer and not necessarily the value that the PWM generator is currently using.

#### Diagram



#### Fields

| Field        | Function                                                                                                                                                                                                                                            |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0<br>VAL2 | <p>Value 2</p> <p>The 16-bit signed value in this buffered register defines the count value to set PWM23 high. This register is not byte accessible.</p> <p><b>NOTE</b></p> <p>The actual behavior takes effect when the counter equals VAL2+1.</p> |

### 31.5.9 Value Register 3 (SM0VAL3 - SM2VAL3)

#### Offset

| Register | Offset |
|----------|--------|
| SM0VAL3  | 16h    |
| SM1VAL3  | 76h    |
| SM2VAL3  | D6h    |

**Function****NOTE**

The VAL3 register is buffered. The value written does not take effect until MCTRL[LDOK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. VAL3 cannot be written when MCTRL[LDOK] is set. Reading VAL3 reads the value in a buffer and not necessarily the value that the PWM generator is currently using.

**Diagram****Fields**

| Field        | Function                                                                                                                                                                                                                                        |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0<br>VAL3 | <p>Value 3</p> <p>The 16-bit signed value in this buffered register defines the count value to set PWM23 low. This register is not byte accessible.</p> <p><b>NOTE</b><br/>The actual behavior takes effect when the counter equals VAL3+1.</p> |

**31.5.10 Value Register 4 (SM0VAL4 - SM2VAL4)****Offset**

| Register | Offset |
|----------|--------|
| SM0VAL4  | 1Ah    |
| SM1VAL4  | 7Ah    |
| SM2VAL4  | DAh    |

**Function****NOTE**

The VAL4 register is buffered. The value written does not take effect until MCTRL[LDOK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. VAL4 cannot be written when MCTRL[LDOK] is set. Reading VAL4 reads the value in a buffer and not necessarily the value that the PWM generator is currently using.

**Diagram****Fields**

| Field        | Function                                                                                                                                                                                                                                         |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0<br>VAL4 | <p>Value 4</p> <p>The 16-bit signed value in this buffered register defines the count value to set PWM45 high. This register is not byte accessible.</p> <p><b>NOTE</b><br/>The actual behavior takes effect when the counter equals VAL4+1.</p> |

**31.5.11 Value Register 5 (SM0VAL5 - SM2VAL5)****Offset**

| Register | Offset |
|----------|--------|
| SM0VAL5  | 1Eh    |
| SM1VAL5  | 7Eh    |
| SM2VAL5  | DEh    |

**Function****NOTE**

The VAL5 register is buffered. The value written does not take effect until MCTRL[LDOCK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. VAL5 cannot be written when MCTRL[LDOCK] is set. Reading VAL5 reads the value in a buffer and not necessarily the value that the PWM generator is currently using.

**Diagram**

| Bits | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| R    |    |    |    |    |    |    |   |   | VAL5 |   |   |   |   |   |   |   |
| W    |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |

Reset    0    0    0    0    |    0    0    0    0    |    0    0    0    0    |    0    0    0    0

**Fields**

| Field        | Function                                                                                                                                                                                                                                        |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0<br>VAL5 | <p>Value 5</p> <p>The 16-bit signed value in this buffered register defines the count value to set PWM45 low. This register is not byte accessible.</p> <p><b>NOTE</b><br/>The actual behavior takes effect when the counter equals VAL5+1.</p> |

**31.5.12 Output Control Register (SM0OCTRL - SM2OCTRL)****Offset**

| Register | Offset |
|----------|--------|
| SM0OCTRL | 22h    |
| SM1OCTRL | 82h    |
| SM2OCTRL | E2h    |

**Function**

Contains output controls for fault states. This register is write-protected by MCTRL2[WRPROT] bits.

**Diagram**

| Bits | 15          | 14          | 13          | 12 | 11   | 10   | 9    | 8 | 7      | 6      | 5      | 4 | 3 | 2 | 1 | 0 |
|------|-------------|-------------|-------------|----|------|------|------|---|--------|--------|--------|---|---|---|---|---|
| R    | PWMA<br>_IN | PWMB<br>_IN | PWMX<br>_IN | 0  | POLA | POLB | POLX | 0 | PWMAFS | PWMBFS | PWMXFS |   |   |   |   |   |
| W    |             |             |             |    | 0    | 0    | 0    | 0 | 0      | 0      | 0      | 0 | 0 | 0 | 0 | 0 |

Reset    0    0    0    0    |    0    0    0    0    |    0    0    0    0    |    0    0    0    0

**Fields**

| Field         | Function                                                                                                                            |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>PWMA_IN | <p>PWM_A Input</p> <p>This bit shows the logic value currently being driven into the PWM_A input. The reset state is undefined.</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14<br>PWMB_IN | PWM_B Input<br><br>This bit shows the logic value currently being driven into the PWM_B input. The reset state is undefined.                                                                                                                                                                                                                                                                                                                                                                  |
| 13<br>PWMX_IN | PWM_X Input<br><br>This bit shows the logic value currently being driven into the PWM_X input. The reset state is undefined.                                                                                                                                                                                                                                                                                                                                                                  |
| 12-11<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 10<br>POLA    | PWM_A Output Polarity<br><br>This bit inverts the PWM_A output polarity.<br><br>0b - PWM_A output not inverted. A high level on the PWM_A pin represents the "on" or "active" state.<br><br>1b - PWM_A output inverted. A low level on the PWM_A pin represents the "on" or "active" state.                                                                                                                                                                                                   |
| 9<br>POLB     | PWM_B Output Polarity<br><br>This bit inverts the PWM_B output polarity.<br><br>0b - PWM_B output not inverted. A high level on the PWM_B pin represents the "on" or "active" state.<br><br>1b - PWM_B output inverted. A low level on the PWM_B pin represents the "on" or "active" state.                                                                                                                                                                                                   |
| 8<br>POLX     | PWM_X Output Polarity<br><br>This bit inverts the PWM_X output polarity.<br><br>0b - PWM_X output not inverted. A high level on the PWM_X pin represents the "on" or "active" state.<br><br>1b - PWM_X output inverted. A low level on the PWM_X pin represents the "on" or "active" state.                                                                                                                                                                                                   |
| 7-6<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5-4<br>PWMAFS | PWM_A Fault State<br><br>These bits determine the fault state for the PWM_A output during fault conditions and Deep Sleep mode. It may also define the output state during Debug mode depending on the setting of CTRL2[DBGEN].<br><br>00b - Output is forced to logic 0 state prior to consideration of output polarity control.<br><br>01b - Output is forced to logic 1 state prior to consideration of output polarity control.<br><br>10b,11b - Output is put in a high-impedance state. |
| 3-2<br>PWMBFS | PWM_B Fault State<br><br>These bits determine the fault state for the PWM_B output during fault conditions and Deep Sleep mode. It may also define the output state during Debug mode depending on the setting of CTRL2[DBGEN].                                                                                                                                                                                                                                                               |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | <p>00b - Output is forced to logic 0 state prior to consideration of output polarity control.</p> <p>01b - Output is forced to logic 1 state prior to consideration of output polarity control.</p> <p>10b,11b - Output is put in a high-impedance state.</p>                                                                                                                                                                                                                                        |
| 1-0<br>PWMXFS | <p>PWM_X Fault State</p> <p>These bits determine the fault state for the PWM_X output during fault conditions and Deep Sleep mode. It may also define the output state during Debug mode depending on the setting of CTRL2[DBGEN].</p> <p>00b - Output is forced to logic 0 state prior to consideration of output polarity control.</p> <p>01b - Output is forced to logic 1 state prior to consideration of output polarity control.</p> <p>10b,11b - Output is put in a high-impedance state.</p> |

### 31.5.13 Status Register (SM0STS - SM2STS)

#### Offset

| Register | Offset |
|----------|--------|
| SM0STS   | 24h    |
| SM1STS   | 84h    |
| SM2STS   | E4h    |

#### Function

Contains Compare and Capture flag status.

#### Diagram

| Bits  | 15 | 14  | 13  | 12  | 11 | 10 | 9 | 8 | 7    | 6    | 5    | 4 | 3 | 2   | 1 | 0 |
|-------|----|-----|-----|-----|----|----|---|---|------|------|------|---|---|-----|---|---|
| R     | 0  | RUF | REF | RF  | 0  |    |   |   | CFX1 | CFX0 | CMPF |   |   |     |   |   |
| W     |    |     | W1C | W1C |    |    |   |   | W1C  | W1C  |      |   |   | W1C |   |   |
| Reset | 0  | 0   | 0   | 0   | 0  | 0  | 0 | 0 | 0    | 0    | 0    | 0 | 0 | 0   | 0 | 0 |

#### Fields

| Field     | Function               |
|-----------|------------------------|
| 15<br>—   | Reserved               |
| 14<br>RUF | Registers Updated Flag |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | <p>This bit is set when one of the INIT, VALx, FRACVALx, or CTRL[PRSC] registers has been written, which indicates potentially non-coherent data in the set of double buffered registers. Clear this bit by a proper reload sequence consisting of a reload signal while MCTRL[LDOKE] = 1. Reset clears this bit.</p> <p>0b - No register update has occurred since last reload.<br/>1b - At least one of the double buffered registers has been updated since the last reload.</p> |
| 13<br>REF   | <p>Reload Error Flag</p> <p>This bit is set when a reload cycle occurs while MCTRL[LDOKE] is 0 and the double buffered registers are in a non-coherent state (STS[RUF] = 1). Clear this bit by writing a logic one to this location. Reset clears this bit.</p> <p>0b - No reload error occurred.<br/>1b - Reload signal occurred with non-coherent data and MCTRL[LDOKE] = 0.</p>                                                                                                  |
| 12<br>RF    | <p>Reload Flag</p> <p>This bit is set at the beginning of every reload cycle regardless of the state of MCTRL[LDOKE]. Clear this bit by writing a logic one to this location when DMAEN[VALDE] is clear (non-DMA mode). This bit can also be cleared by the DMA done signal when DMAEN[VALDE] is set (DMA mode) . Reset clears this bit.</p> <p>0b - No new reload cycle since last STS[RF] clearing<br/>1b - New reload cycle since last STS[RF] clearing</p>                      |
| 11-8<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7<br>CFX1   | <p>Capture Flag X1</p> <p>This bit is set when a capture event occurs on the Capture X1 circuit . This bit is cleared by writing a one to this bit position if DMAEN[CX1DE] is clear (non-DMA mode) or by the DMA done signal if DMAEN[CX1DE] is set (DMA mode) . Reset clears this bit.</p>                                                                                                                                                                                        |
| 6<br>CFX0   | <p>Capture Flag X0</p> <p>This bit is set when a capture event occurs on the Capture X0 circuit . This bit is cleared by writing a one to this bit position if DMAEN[CX0DE] is clear (non-DMA mode) or by the DMA done signal if DMAEN[CX0DE] is set (DMA mode) . Reset clears this bit.</p>                                                                                                                                                                                        |
| 5-0<br>CMPE | <p>Compare Flags</p> <p>These bits are set when the submodule counter value matches the value of one of the VALx registers. Clear these bits by writing a 1 to a bit position.</p> <p>00_0000b - No compare event has occurred for a particular VALx value.<br/>00_0001b - A compare event has occurred for a particular VALx value.</p>                                                                                                                                            |

### 31.5.14 Interrupt Enable Register (SM0INTEN - SM2INTEN)

#### Offset

| Register | Offset |
|----------|--------|
| SM0INTEN | 26h    |
| SM1INTEN | 86h    |
| SM2INTEN | E6h    |

#### Function

Contains Compare and Capture interrupt enables.

#### Diagram



#### Fields

| Field      | Function                                                                                                                                                                                                                                       |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-14<br>— | Reserved                                                                                                                                                                                                                                       |
| 13<br>REIE | Reload Error Interrupt Enable<br>This bit enables the reload error flag, STS[REF], to generate CPU interrupt requests. Reset clears this bit.<br>0b - STS[REF] CPU interrupt requests disabled<br>1b - STS[REF] CPU interrupt requests enabled |
| 12<br>RIE  | Reload Interrupt Enable<br>This bit enables the reload flag, STS[RF], to generate CPU interrupt requests. Reset clears this bit.<br>0b - STS[RF] CPU interrupt requests disabled<br>1b - STS[RF] CPU interrupt requests enabled                |
| 11-8<br>—  | Reserved                                                                                                                                                                                                                                       |
| 7<br>CX1IE | Capture X 1 Interrupt Enable<br>This bit allows the STS[CFX1] flag to create an interrupt request to the CPU. Do not set this bit and DMAEN[CX1DE].                                                                                            |

Table continues on the next page...

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                 |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | 0b - Interrupt request disabled for STS[CFX1].<br>1b - Interrupt request enabled for STS[CFX1].                                                                                                                                                                                          |
| 6<br>CX0IE   | Capture X 0 Interrupt Enable<br>This bit allows the STS[CFX0] flag to create an interrupt request to the CPU. Do not set this bit and DMAEN[CX0DE].<br>0b - Interrupt request disabled for STS[CFX0].<br>1b - Interrupt request enabled for STS[CFX0].                                   |
| 5-0<br>CMPIE | Compare Interrupt Enables<br>These bits enable the STS[CMPPF] flags to cause a compare interrupt request to the CPU.<br>00_0000b - The corresponding STS[CMPPF] bit will not cause an interrupt request.<br>00_0001b - The corresponding STS[CMPPF] bit will cause an interrupt request. |

### 31.5.15 DMA Enable Register (SM0DMAEN - SM2DMAEN)

#### Offset

| Register | Offset |
|----------|--------|
| SM0DMAEN | 28h    |
| SM1DMAEN | 88h    |
| SM2DMAEN | E8h    |

#### Function

Contains controls for DMA. This register is write-protected by MCTRL2[WRPROT] bits.

#### Diagram



#### Fields

| Field | Function |
|-------|----------|
| 15-10 | Reserved |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 9<br>VALDE    | <p><b>Value Registers DMA Enable</b></p> <p>This bit enables DMA write requests for the VALx and FRACVALx registers when STS[RF] is set. Reset clears this bit.</p> <p>0b - DMA write requests disabled<br/>1b - Enabled. DMA write requests for the VALx and FRACVALx registers enabled</p>                                                                                                                                                                                                                                                                                                                                          |
| 8<br>FAND     | <p><b>FIFO Watermark AND Control</b></p> <p>This bit works in conjunction with the DMAEN[CAPTDE] field when it is set to watermark mode (DMAEN[CAPTDE] = 01). While DMAEN[CAxDE], DMAEN[CBxDE], and DMAEN[CXxDE] determine which FIFO watermarks the DMA read request is sensitive to. This bit determines if the selected watermarks are AND'ed together or OR'ed together to create the request.</p> <p>0b - Selected FIFO watermarks are OR'ed together.<br/>1b - Selected FIFO watermarks are AND'ed together.</p>                                                                                                                |
| 7-6<br>CAPTDE | <p><b>Capture DMA Enable Source Select</b></p> <p>These bits select the source of enabling the DMA read requests for the capture FIFOs. Reset clears these bits.</p> <p>00b - Read DMA requests disabled.<br/>01b - Exceeding a FIFO watermark sets the DMA read request. This requires at least one of DMAEN[CA1DE], DMAEN[CA0DE], DMAEN[CB1DE], DMAEN[CB0DE], DMAEN[CX1DE], or DMAEN[CX0DE] to be set to determine which watermark(s) the DMA request is sensitive.<br/>10b - A local synchronization (VAL1 matches counter) sets the read DMA request.<br/>11b - A local reload (STS[RF] being set) sets the read DMA request.</p> |
| 5-2<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1<br>CX1DE    | <p><b>Capture X1 FIFO DMA Enable</b></p> <p>This bit enables DMA read requests for the Capture X1 FIFO data when STS[CFX1] is set. Reset clears this bit. Do not set both this bit and INTEN[CX1IE].</p>                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0<br>CX0DE    | <p><b>Capture X0 FIFO DMA Enable</b></p> <p>This bit enables DMA read requests for the Capture X0 FIFO data when STS[CFX0] is set. Reset clears this bit. Do not set both this bit and INTEN[CX0IE].</p>                                                                                                                                                                                                                                                                                                                                                                                                                              |

### 31.5.16 Output Trigger Control Register (SM0TCTRL - SM2TCTRL)

#### Offset

| Register | Offset |
|----------|--------|
| SM0TCTRL | 2Ah    |
| SM1TCTRL | 8Ah    |
| SM2TCTRL | EAh    |

#### Function

Contains trigger controls. This register is write-protected by MCTRL2[WRPROT] bits.

#### Diagram



#### Fields

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>PWAOT0 | Mux Output Trigger 0 Source Select<br><br>This bit selects which signal to bring out on the PWM's PWM_MUX_TRIG0 port.<br><br>0b - Route the PWM_OUT_TRIG0 signal to PWM_MUX_TRIG0 port.<br>1b - Route the PWM_A output to the PWM_MUX_TRIG0 port.                                                                                                                                                                                                                      |
| 14<br>PWBOT1 | Mux Output Trigger 1 Source Select<br><br>This bit selects which signal to bring out on the PWM's PWM_MUX_TRIG1 port.<br><br>0b - Route the PWM_OUT_TRIG1 signal to PWM_MUX_TRIG1 port.<br>1b - Route the PWM_B output to the PWM_MUX_TRIG1 port.                                                                                                                                                                                                                      |
| 13<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 12<br>TRGFRQ | Trigger Frequency<br><br>This bit allows control over the frequency of the trigger outputs when using non-zero values of CTRL[LDFQ].<br><br>0b - Trigger outputs are generated during every PWM period even if the PWM is not reloaded every period due to CTRL[LDFQ] being non-zero.<br>1b - Trigger outputs are generated only during the final PWM period prior to a reload opportunity when the PWM is not reloaded every period due to CTRL[LDFQ] being non-zero. |

Table continues on the next page...

*Table continued from the previous page...*

| Field              | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11-6<br>—          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5-0<br>OUT_TRIG_EN | <p>Output Trigger Enables</p> <p>These bits enable the generation of PWM_OUT_TRIG0 and PWM_OUT_TRIG1 outputs based on the counter value matching the value in one or more of the VAL0-5 registers.</p> <p><b>NOTE</b></p> <p>Due to delays in creating the PWM outputs, the output trigger signals lead the PWM output edges by 2-3 clock cycles depending on the fractional cycle value being used.</p> <p>1x_xxxxb - PWM_OUT_TRIG1 will set when the counter value matches the VAL5 value.<br/>     x1_xxxxb - PWM_OUT_TRIG0 will set when the counter value matches the VAL4 value.<br/>     xx_1xxxb - PWM_OUT_TRIG1 will set when the counter value matches the VAL3 value.<br/>     xx_x1xb - PWM_OUT_TRIG0 will set when the counter value matches the VAL2 value.<br/>     xx_xx1xb - PWM_OUT_TRIG1 will set when the counter value matches the VAL1 value.<br/>     xx_xxx1b - PWM_OUT_TRIG0 will set when the counter value matches the VAL0 value.</p> |

### 31.5.17 Fault Disable Mapping Register 0 (SM0DISMAP0 - SM2DISMAP0)

#### Offset

| Register   | Offset |
|------------|--------|
| SM0DISMAP0 | 2Ch    |
| SM1DISMAP0 | 8Ch    |
| SM2DISMAP0 | ECh    |

#### Function

This register determines which PWM pins are disabled by the fault protection inputs. Reset sets all of the bits in the fault disable mapping register. This register is write-protected by MCTRL2[WRPROT] bits.

**Diagram**

| Bits | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8     | 7 | 6 | 5 | 4     | 3 | 2 | 1 | 0     |
|------|----|----|----|----|----|----|---|-------|---|---|---|-------|---|---|---|-------|
| R    |    |    |    | 1  |    |    |   |       |   |   |   |       |   |   |   |       |
| W    |    |    |    |    |    |    |   | DIS0X |   |   |   | DIS0B |   |   |   | DIS0A |

Reset    1    1    1    1    1    1    1    1    1    1    1    1    1    1    1    1

**Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11-8<br>DIS0X | <b>PWM_X Fault Disable Mask 0</b><br>Each of the four bits of this field is one-to-one associated with the four FAULTx inputs of fault channel 0. The PWM_X output is turned off if there is a logic 1 on a FAULTx input and a 1 in the corresponding bit of this field. DIS0X[0] is associated with FAULT0. DIS0X[1] is associated with FAULT1. DIS0X[2] is associated with FAULT2. DIS0X[3] is associated with FAULT3.<br>A reset sets all bits in this field. |
| 7-4<br>DIS0B  | <b>PWM_B Fault Disable Mask 0</b><br>Each of the four bits of this field is one-to-one associated with the four FAULTx inputs of fault channel 0. The PWM_B output is turned off if there is a logic 1 on a FAULTx input and a 1 in the corresponding bit of this field. DIS0B[0] is associated with FAULT0. DIS0B[1] is associated with FAULT1. DIS0B[2] is associated with FAULT2. DIS0B[3] is associated with FAULT3.<br>A reset sets all bits in this field. |
| 3-0<br>DIS0A  | <b>PWM_A Fault Disable Mask 0</b><br>Each of the four bits of this field is one-to-one associated with the four FAULTx inputs of fault channel 0. The PWM_A output is turned off if there is a logic 1 on a FAULTx input and a 1 in the corresponding bit of this field. DIS0A[0] is associated with FAULT0. DIS0A[1] is associated with FAULT1. DIS0A[2] is associated with FAULT2. DIS0A[3] is associated with FAULT3.<br>A reset sets all bits in this field. |

**31.5.18 Deadtime Count Register 0 (SM0DTCNT0 - SM2DTCNT0)****Offset**

| Register  | Offset |
|-----------|--------|
| SM0DTCNT0 | 30h    |
| SM1DTCNT0 | 90h    |
| SM2DTCNT0 | F0h    |

## Function

Deadtime operation applies only to complementary channel operation. The values written to the DTCNTx registers are in terms of IPBus clock cycles regardless of the setting of CTRL[PRSC] and/or CTRL2[CLK\_SEL]. Reset sets the deadtime count registers to a default value of 0x07FF, selecting a deadtime of 2047 IPBus clock cycles, when fractional delay is not enabled. The DTCNTx registers are not byte accessible.

## Diagram



## Fields

| Field          | Function                                                                                                                                          |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-11<br>—     | Reserved                                                                                                                                          |
| 10-0<br>DTCNT0 | Deadtime Count Register 0<br>This field is used to control the deadtime during 0 to 1 transitions of the PWM_A output (assuming normal polarity). |

## 31.5.19 Deadtime Count Register 1 (SM0DTCNT1 - SM2DTCNT1)

### Offset

| Register  | Offset |
|-----------|--------|
| SM0DTCNT1 | 32h    |
| SM1DTCNT1 | 92h    |
| SM2DTCNT1 | F2h    |

### Function

Deadtime operation applies only to complementary channel operation. The values written to the DTCNTx registers are in terms of IPBus clock cycles regardless of the setting of CTRL[PRSC] and/or CTRL2[CLK\_SEL]. Reset sets the deadtime count registers to a default value of 0x07FF, selecting a deadtime of 2047 IPBus clock cycles, when fractional delay is not enabled. The DTCNTx registers are not byte accessible.

**Diagram**

| Bits | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0      |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------|
| R    | 0  |    |    |    |    |    |   |   |   |   |   |   |   |   |   | DTCNT1 |
| W    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |        |

Reset    0    0    0    0    0    1    1    1    1    1    1    1    1    1    1    1

**Fields**

| Field  | Function                                                                                                |
|--------|---------------------------------------------------------------------------------------------------------|
| 15-11  | Reserved                                                                                                |
| 10-0   | Deadtime Count Register 1                                                                               |
| DTCNT1 | This field is used to control the deadtime during 0 to 1 transitions of the complementary PWM_B output. |

**31.5.20 Capture Control X Register (SM0CAPTCTRLX)****Offset**

| Register     | Offset |
|--------------|--------|
| SM0CAPTCTRLX | 3Ch    |

**Function**

Contains capture controls for mode X. This register is write-protected by MCTRL2[WRPROT] bits.

**Diagram**

| Bits | 15     | 14 | 13 | 12     | 11 | 10 | 9     | 8 | 7              | 6            | 5 | 4     | 3 | 2     | 1            | 0    |
|------|--------|----|----|--------|----|----|-------|---|----------------|--------------|---|-------|---|-------|--------------|------|
| R    | CX1CNT |    |    | CX0CNT |    |    | CFXWM |   | EDGC<br>NTX... | INP_<br>SELX |   | EDGX1 |   | EDGX0 | ONES<br>HOTX | ARMX |
| W    |        |    |    |        |    |    |       |   | 0              | 0            |   | 0     | 0 | 0     | 0            | 0    |

Reset    0    0    0    0    0    0    0    0    0    0    0    0    0    0    0    0

**Fields**

| Field  | Function                                                                           |
|--------|------------------------------------------------------------------------------------|
| 15-13  | Capture X1 FIFO Word Count                                                         |
| CX1CNT | This field reflects the number of words in the Capture X1 FIFO. (FIFO depth is 1.) |
| 12-10  | Capture X0 FIFO Word Count                                                         |
| CX0CNT | This field reflects the number of words in the Capture X0 FIFO. (FIFO depth is 1.) |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9-8<br>CFXWM    | Capture X FIFOs Water Mark<br><br>This field represents the water mark level for capture X FIFOs. The capture flags, STS[CFX1] and STS[CFX0], will not be set until the word count of the corresponding FIFO is greater than this water mark level. (FIFO depth is 1.)                                                                                                                                                                                                                                                                                                                                                                                             |
| 7<br>EDGCNTX_EN | Edge Counter X Enable<br><br>This bit enables the edge counter which counts rising and falling edges on the PWM_X input signal.<br>0b - Edge counter disabled and held in reset<br>1b - Edge counter enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 6<br>INP_SELX   | Input Select X<br><br>This bit selects between the raw PWM_X input signal and the output of the edge counter/compare circuitry as the source for the input capture circuit.<br>0b - Raw PWM_X input signal selected as source.<br>1b - Edge Counter. Output of edge counter/compare selected as source. When this bitfield is set to 1, the internal edge counter is enabled and the rising and/or falling edges specified by the CAPTCTRLX[EDGX0] and CAPTCTRLX[EDGX1] fields are ignored. The software must place a value other than 00 in either or both of the CAPTCTRLX[EDGX0] and/or CAPTCTRLX[EDGX1] fields to enable one or both of the capture registers. |
| 5-4<br>EDGX1    | Edge X 1<br><br>These bits control the input capture 1 circuitry by determining which input edges cause a capture event.<br>00b - Disabled<br>01b - Capture falling edges<br>10b - Capture rising edges<br>11b - Capture any edge                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3-2<br>EDGX0    | Edge X 0<br><br>These bits control the input capture 0 circuitry by determining which input edges cause a capture event.<br>00b - Disabled<br>01b - Capture falling edges<br>10b - Capture rising edges<br>11b - Capture any edge                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1<br>ONESHOTX   | One Shot Mode Aux<br><br>This field selects between free running and one shot mode for the input capture circuitry.<br>0b - Free Running. Free running mode is selected if both capture circuits are enabled, then capture circuit 0 is armed first after the ARMX bit is set. Once a capture occurs, capture circuit 0 is disarmed, and capture circuit 1 is armed. After capture circuit 1 performs a capture, it is                                                                                                                                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | <p>disarmed, and capture circuit 0 is re-armed. The process continues indefinitely. If only one of the capture circuits is enabled, then captures continue indefinitely on the enabled capture circuit.</p> <p>1b - One Shot. One shot mode is selected if both capture circuits are enabled, then capture circuit 0 is armed first after the ARMX bit is set. Once a capture occurs, capture circuit 0 is disarmed, and capture circuit 1 is armed. After capture circuit 1 performs a capture, it is disarmed, and the ARMX bit is cleared. No further captures are performed until the ARMX bit is set again. If only one of the capture circuits is enabled, then a single capture occurs on the enabled capture circuit and the ARMX bit is then cleared.</p> |
| 0<br>ARMX | <p>Arm X</p> <p>Setting this bit high starts the input capture process. This bit can be cleared at any time to disable input capture operation. This bit is self-cleared when in one shot mode and one or more of the enabled capture circuits has had a capture event.</p> <p>0b - Input capture operation is disabled.</p> <p>1b - Input capture operation as specified by CAPTCTRLX[EDGXx] is enabled.</p>                                                                                                                                                                                                                                                                                                                                                      |

### 31.5.21 Capture Compare X Register (SM0CAPTCOMPX)

#### Offset

| Register     | Offset |
|--------------|--------|
| SM0CAPTCOMPX | 3Eh    |

#### Function

Contains capture and control values for mode X. This register is write-protected by MCTRL2[WRPROT] bits.

#### Diagram



#### Fields

| Field           | Function                                                                                                                  |
|-----------------|---------------------------------------------------------------------------------------------------------------------------|
| 15-8<br>EDGCNTX | Edge Counter X<br>This field contains the edge counter value for the PWM_X input capture circuitry.                       |
| 7-0<br>EDGCMPX  | Edge Compare X<br>This field is the compare value associated with the edge counter for the PWM_X input capture circuitry. |

### 31.5.22 Capture Value 0 Register (SM0CVAL0)

#### Offset

| Register | Offset |
|----------|--------|
| SM0CVAL0 | 40h    |

#### Function

Writing this register generates bus transfer error.

#### Diagram



#### Fields

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0<br>CAPTVAL0 | Capture Value 0<br><br>This field stores the value captured from the submodule counter. Exactly when this capture occurs is defined by CAPTCTRLX[EDGX0]. Each capture increases the value of CAPTCTRLX[CX0CNT] by 1 until the maximum value is reached. Each read of this field decreases the value of CAPTCTRLX[CX0CNT] by 1 until 0 is reached. This field is not byte accessible. |

### 31.5.23 Capture Value 0 Cycle Register (SM0CVAL0CYC)

#### Offset

| Register    | Offset |
|-------------|--------|
| SM0CVAL0CYC | 42h    |

#### Function

Writing this register generates bus transfer error.

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0        |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------|
| R     |    |    |    |    |    |    |   | 0 |   |   |   |   |   |   |   | CVAL0CYC |
| W     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |          |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0        |

**Fields**

| Field           | Function                                                                                                                                                                                                                  |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-4<br>—       | Reserved                                                                                                                                                                                                                  |
| 3-0<br>CVAL0CYC | Capture Value 0 Cycle<br>This field stores the cycle number corresponding to the value captured in CVAL0. This field is incremented each time the counter is loaded with the INIT value at the end of a PWM modulo cycle. |

**31.5.24 Capture Value 1 Register (SM0CVAL1)****Offset**

| Register | Offset |
|----------|--------|
| SM0CVAL1 | 44h    |

**Function**

Writing this register generates bus transfer error.

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0        |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------|
| R     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | CAPTVAL1 |
| W     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |          |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0        |

**Fields**

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0<br>CAPTVAL1 | Capture Value 1<br>This field stores the value captured from the submodule counter when this capture occurs is defined by CAPTCTRLX[EDGX1]. Each capture increases the value of CAPTCTRLX[CX1CNT] by 1 until the maximum value is reached. Each read of this field decreases the value of CAPTCTRLX[CX1CNT] by 1 until 0 is reached. This field is not byte accessible. |

### 31.5.25 Capture Value 1 Cycle Register (SM0CVAL1CYC)

#### Offset

| Register    | Offset |
|-------------|--------|
| SM0CVAL1CYC | 46h    |

#### Function

Writing this register generates bus transfer error.

#### Diagram

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0        |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------|
| R     |    |    |    |    |    |    |   | 0 |   |   |   |   |   |   |   | CVAL1CYC |
| W     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |          |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0        |

#### Fields

| Field           | Function                                                                                                                                                                                                                                                               |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-4<br>—       | Reserved                                                                                                                                                                                                                                                               |
| 3-0<br>CVAL1CYC | Capture Value 1 Cycle<br><br>This field stores the cycle number corresponding to the value captured in CVAL1. This field is incremented each time the counter is loaded with the INIT value at the end of a PWM modulo cycle.<br><br>Resets to 0 at POR or hard reset. |

### 31.5.26 Capture PWM\_X Input Filter Register (SM0CAPTFILTX - SM2CAPTFILTX)

#### Offset

| Register     | Offset |
|--------------|--------|
| SM0CAPTFILTX | 5Eh    |
| SM1CAPTFILTX | B Eh   |
| SM2CAPTFILTX | 11Eh   |

#### Function

Input filter considerations include:

- The CAPTX\_FILT\_PER value should be set such that the sampling period is larger than the period of the expected noise. This way a noise spike will only corrupt one sample. The CAPTX\_FILT\_CNT value should be chosen to reduce the probability of noisy samples causing an incorrect transition to be recognized. The probability of an incorrect transition is defined as the probability of an incorrect sample raised to the CAPTX\_FILT\_CNT+3 power.

- The values of FILT\_PER and CAPTX\_FILT\_CNT must also be traded off against the desire for minimal latency in recognizing input transitions. Turning on the input filter (setting CAPTX\_FILT\_PER to a non-zero value) introduces a latency of ((CAPTX\_FILT\_CNT+4) x CAPTX\_FILT\_PER x IPBus clock period).

**NOTE**

When the filter is enabled, there is a combinational path to disable the PWM outputs to ensure rapid response to input capture conditions if the PWM module loses its clock. The latency induced by the filter will be seen in the time to set FSTS[FFFLAG] and FSTS[FFPIN].

This register is not byte accessible

This register is write-protected by MCTRL2[WRPROT] bits.

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10             | 9 | 8 | 7 | 6 | 5 | 4              | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----------------|---|---|---|---|---|----------------|---|---|---|---|
| R     | 0  | 0  | 0  | 0  | 0  | 0              | 0 | 0 | 0 | 0 | 0 | 0              | 0 | 0 | 0 | 0 |
| W     |    |    |    |    |    | CAPTX_FILT_CNT |   |   |   |   |   | CAPTX_FILT_PER |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0              | 0 | 0 | 0 | 0 | 0 | 0              | 0 | 0 | 0 | 0 |

**Fields**

| Field                  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-11<br>—             | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 10-8<br>CAPTX_FILT_CNT | <p><b>Input Capture Filter Count</b></p> <p>These bits represent the number of consecutive samples that must agree prior to the input filter accepting an input transition. The number of samples is the decimal value of this field plus three: the bit field value of 0-7 represents 3-10 samples, respectively. The value of CAPTX_FILT_CNT affects the input latency.</p>                                                                                                                                                                                                                     |
| 7-0<br>CAPTX_FILT_PER  | <p><b>Input Capture Filter Period</b></p> <p>This field applies universally to all capture inputs.</p> <p>These bits represent the sampling period (in IPBus clock cycles) of the input capture pin input filter. Each input is sampled multiple times at the rate specified by this field. If CAPTX_FILT_PER is 0x00 (default), then the input filter is bypassed. The value of CAPTX_FILT_PER affects the input latency.</p> <p><b>NOTE</b><br/>When changing values for CAPTX_FILT_PER from one non-zero value to another non-zero value, first write a value of zero to clear the filter.</p> |

**31.5.27 Capture Control X Register (SM1CAPTCTRLX)****Offset**

| Register     | Offset |
|--------------|--------|
| SM1CAPTCTRLX | 9Ch    |

**Function**

Contains capture controls for mode X. This register is write-protected by MCTRL2[WRPROT] bits.

**Diagram**

| Bits | 15     | 14 | 13     | 12 | 11    | 10 | 9          | 8        | 7 | 6     | 5 | 4     | 3 | 2        | 1 | 0    |
|------|--------|----|--------|----|-------|----|------------|----------|---|-------|---|-------|---|----------|---|------|
| R    | CX1CNT |    | CX0CNT |    | CFXWM |    | EDGCNTX... | INP_SELX |   | EDGX1 |   | EDGX0 |   | ONESHOTX |   | ARMX |
| W    |        |    |        |    |       |    | 0          | 0        | 0 | 0     | 0 | 0     | 0 | 0        | 0 | 0    |

**Fields**

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-13<br>CX1CNT | Capture X1 FIFO Word Count<br><br>This field reflects the number of words in the Capture X1 FIFO. (FIFO depth is 1.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 12-10<br>CX0CNT | Capture X0 FIFO Word Count<br><br>This field reflects the number of words in the Capture X0 FIFO. (FIFO depth is 1.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 9-8<br>CFXWM    | Capture X FIFOs Water Mark<br><br>This field represents the water mark level for capture X FIFOs. The capture flags, STS[CFX1] and STS[CFX0], will not be set until the word count of the corresponding FIFO is greater than this water mark level. (FIFO depth is 1.)                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7<br>EDGCNTX_EN | Edge Counter X Enable<br><br>This bit enables the edge counter which counts rising and falling edges on the PWM_X input signal.<br><br>0b - Edge counter disabled and held in reset<br>1b - Edge counter enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 6<br>INP_SELX   | Input Select X<br><br>This bit selects between the raw PWM_X input signal and the output of the edge counter/compare circuitry as the source for the input capture circuit.<br><br>0b - Raw PWM_X input signal selected as source.<br>1b - Edge Counter. Output of edge counter/compare selected as source. When this bitfield is set to 1, the internal edge counter is enabled and the rising and/or falling edges specified by the CAPTCTRLX[EDGX0] and CAPTCTRLX[EDGX1] fields are ignored. The software must place a value other than 00 in either or both of the CAPTCTRLX[EDGX0] and/or CAPTCTRLX[EDGX1] fields to enable one or both of the capture registers. |
| 5-4<br>EDGX1    | Edge X 1<br><br>These bits control the input capture 1 circuitry by determining which input edges cause a capture event.<br><br>00b - Disabled<br>01b - Capture falling edges                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | 10b - Capture rising edges<br>11b - Capture any edge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3-2<br>EDGX0  | Edge X 0<br>These bits control the input capture 0 circuitry by determining which input edges cause a capture event.<br>00b - Disabled<br>01b - Capture falling edges<br>10b - Capture rising edges<br>11b - Capture any edge                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1<br>ONESHOTX | One Shot Mode Aux<br>This field selects between free running and one shot mode for the input capture circuitry.<br>0b - Free Running. Free running mode is selected if both capture circuits are enabled, then capture circuit 0 is armed first after the ARMX bit is set. Once a capture occurs, capture circuit 0 is disarmed, and capture circuit 1 is armed. After capture circuit 1 performs a capture, it is disarmed, and capture circuit 0 is re-armed. The process continues indefinitely. If only one of the capture circuits is enabled, then captures continue indefinitely on the enabled capture circuit.<br>1b - One Shot. One shot mode is selected if both capture circuits are enabled, then capture circuit 0 is armed first after the ARMX bit is set. Once a capture occurs, capture circuit 0 is disarmed, and capture circuit 1 is armed. After capture circuit 1 performs a capture, it is disarmed, and the ARMX bit is cleared. No further captures are performed until the ARMX bit is set again. If only one of the capture circuits is enabled, then a single capture occurs on the enabled capture circuit and the ARMX bit is then cleared. |
| 0<br>ARMX     | Arm X<br>Setting this bit high starts the input capture process. This bit can be cleared at any time to disable input capture operation. This bit is self-cleared when in one shot mode and one or more of the enabled capture circuits has had a capture event.<br>0b - Input capture operation is disabled.<br>1b - Input capture operation as specified by CAPTCTRLX[EDGXx] is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

### 31.5.28 Capture Compare X Register (SM1CAPTCOMPX)

#### Offset

| Register     | Offset |
|--------------|--------|
| SM1CAPTCOMPX | 9Eh    |

#### Function

Contains capture and control values for mode X. This register is write-protected by MCTRL2[WRPROT] bits.

**Diagram****Fields**

| Field           | Function                                                                                                                  |
|-----------------|---------------------------------------------------------------------------------------------------------------------------|
| 15-8<br>EDGCNTX | Edge Counter X<br>This field contains the edge counter value for the PWM_X input capture circuitry.                       |
| 7-0<br>EDGCMPPX | Edge Compare X<br>This field is the compare value associated with the edge counter for the PWM_X input capture circuitry. |

**31.5.29 Capture Value 0 Register (SM1CVAL0)****Offset**

| Register | Offset |
|----------|--------|
| SM1CVAL0 | A0h    |

**Function**

Writing this register generates bus transfer error.

**Diagram****Fields**

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                         |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0<br>CAPTVAL0 | Capture Value 0<br>This field stores the value captured from the submodule counter. Exactly when this capture occurs is defined by CAPTCTRLX[EDGX0]. Each capture increases the value of CAPTCTRLX[CX0CNT] by 1 until the maximum value is reached. Each read of this field decreases the value of CAPTCTRLX[CX0CNT] by 1 until 0 is reached. This field is not byte accessible. |

### 31.5.30 Capture Value 0 Cycle Register (SM1CVAL0CYC)

#### Offset

| Register    | Offset |
|-------------|--------|
| SM1CVAL0CYC | A2h    |

#### Function

Writing this register generates bus transfer error.

#### Diagram



#### Fields

| Field           | Function                                                                                                                                                                                                                      |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-4<br>—       | Reserved                                                                                                                                                                                                                      |
| 3-0<br>CVAL0CYC | Capture Value 0 Cycle<br><br>This field stores the cycle number corresponding to the value captured in CVAL0. This field is incremented each time the counter is loaded with the INIT value at the end of a PWM modulo cycle. |

### 31.5.31 Capture Value 1 Register (SM1CVAL1)

#### Offset

| Register | Offset |
|----------|--------|
| SM1CVAL1 | A4h    |

#### Function

Writing this register generates bus transfer error.

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |   |   | CAPTVAL1 |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0        | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Fields**

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                    |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0<br>CAPTVAL1 | Capture Value 1<br><br>This field stores the value captured from the submodule counter when this capture occurs is defined by CAPTCTRLX[EDGX1]. Each capture increases the value of CAPTCTRLX[CX1CNT] by 1 until the maximum value is reached. Each read of this field decreases the value of CAPTCTRLX[CX1CNT] by 1 until 0 is reached. This field is not byte accessible. |

**31.5.32 Capture Value 1 Cycle Register (SM1CVAL1CYC)****Offset**

| Register    | Offset |
|-------------|--------|
| SM1CVAL1CYC | A6h    |

**Function**

Writing this register generates bus transfer error.

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2        | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|----------|---|---|
| R     |    |    |    |    |    |    |   |   | 0 |   |   |   |   | CVAL1CYC |   |   |
| W     |    |    |    |    |    |    |   |   |   |   |   |   |   |          |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0        | 0 | 0 |

**Fields**

| Field           | Function                                                                                                                                                                                                                                                               |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-4<br>—       | Reserved                                                                                                                                                                                                                                                               |
| 3-0<br>CVAL1CYC | Capture Value 1 Cycle<br><br>This field stores the cycle number corresponding to the value captured in CVAL1. This field is incremented each time the counter is loaded with the INIT value at the end of a PWM modulo cycle.<br><br>Resets to 0 at POR or hard reset. |

### 31.5.33 Phase Delay Register (SM1PHASEDLY - SM2PHASEDLY)

#### Offset

| Register    | Offset |
|-------------|--------|
| SM1PHASEDLY | B8h    |
| SM2PHASEDLY | 118h   |

#### Function

The 16-bit unsigned value in this buffered register defines the delay from the master sync signal of submodule 0 to the time that this submodule recognizes the master sync in PWM clock periods. CTRL2[INIT\_SEL] must be set to 10b to select the master sync signal as the source for initialization when using this register. Setting this register with a non-zero value and using the master sync signal as the initialization source, allows the output of this submodule to be a fixed number of cycles delayed from submodule 0. For PWM operation, the buffered contents of this register are updated at the start of every PWM cycle. This field is not byte accessible.

#### NOTE

The PHASEDLY register is buffered. The value written does not take effect until MCTRL[LDOK] is set and the next PWM load cycle begins or CTRL[LDMOD] is set. This register cannot be written when MCTRL[LDOK] is set. Reading PHASEDLY reads the value in a buffer and not necessarily the value that the PWM generator is currently using. Also, the value of this register should not be set to a value larger than the period defined in submodule 0.

#### Diagram



#### Fields

| Field    | Function                    |
|----------|-----------------------------|
| 15-0     | Initial Count Register Bits |
| PHASEDLY |                             |

### 31.5.34 Capture Control X Register (SM2CAPTCTRLX)

#### Offset

| Register     | Offset |
|--------------|--------|
| SM2CAPTCTRLX | FCh    |

#### Function

Contains capture controls for mode X. This register is write-protected by MCTRL2[WRPROT] bits.

**Diagram**

| Bits | 15     | 14 | 13     | 12 | 11    | 10 | 9          | 8        | 7 | 6     | 5 | 4     | 3 | 2        | 1 | 0    |
|------|--------|----|--------|----|-------|----|------------|----------|---|-------|---|-------|---|----------|---|------|
| R    | CX1CNT |    | CX0CNT |    | CFXWM |    | EDGCNTX... | INP_SELX |   | EDGX1 |   | EDGX0 |   | ONESHOTX |   | ARMX |
| W    |        |    |        |    |       |    | 0          | 0        | 0 | 0     | 0 | 0     | 0 | 0        | 0 | 0    |

**Fields**

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-13<br>CX1CNT | Capture X1 FIFO Word Count<br>This field reflects the number of words in the Capture X1 FIFO. (FIFO depth is 1.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 12-10<br>CX0CNT | Capture X0 FIFO Word Count<br>This field reflects the number of words in the Capture X0 FIFO. (FIFO depth is 1.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 9-8<br>CFXWM    | Capture X FIFOs Water Mark<br>This field represents the water mark level for capture X FIFOs. The capture flags, STS[CFX1] and STS[CFX0], will not be set until the word count of the corresponding FIFO is greater than this water mark level. (FIFO depth is 1.)                                                                                                                                                                                                                                                                                                                                                                                             |
| 7<br>EDGCNTX_EN | Edge Counter X Enable<br>This bit enables the edge counter which counts rising and falling edges on the PWM_X input signal.<br>0b - Edge counter disabled and held in reset<br>1b - Edge counter enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 6<br>INP_SELX   | Input Select X<br>This bit selects between the raw PWM_X input signal and the output of the edge counter/compare circuitry as the source for the input capture circuit.<br>0b - Raw PWM_X input signal selected as source.<br>1b - Edge Counter. Output of edge counter/compare selected as source. When this bitfield is set to 1, the internal edge counter is enabled and the rising and/or falling edges specified by the CAPTCTRLX[EDGX0] and CAPTCTRLX[EDGX1] fields are ignored. The software must place a value other than 00 in either or both of the CAPTCTRLX[EDGX0] and/or CAPTCTRLX[EDGX1] fields to enable one or both of the capture registers. |
| 5-4<br>EDGX1    | Edge X 1<br>These bits control the input capture 1 circuitry by determining which input edges cause a capture event.<br>00b - Disabled<br>01b - Capture falling edges<br>10b - Capture rising edges<br>11b - Capture any edge                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3-2             | Edge X 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EDGX0         | <p>These bits control the input capture 0 circuitry by determining which input edges cause a capture event.</p> <p>00b - Disabled<br/>01b - Capture falling edges<br/>10b - Capture rising edges<br/>11b - Capture any edge</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1<br>ONESHOTX | <p>One Shot Mode Aux</p> <p>This field selects between free running and one shot mode for the input capture circuitry.</p> <p>0b - Free Running. Free running mode is selected if both capture circuits are enabled, then capture circuit 0 is armed first after the ARMX bit is set. Once a capture occurs, capture circuit 0 is disarmed, and capture circuit 1 is armed. After capture circuit 1 performs a capture, it is disarmed, and capture circuit 0 is re-armed. The process continues indefinitely. If only one of the capture circuits is enabled, then captures continue indefinitely on the enabled capture circuit.</p> <p>1b - One Shot. One shot mode is selected if both capture circuits are enabled, then capture circuit 0 is armed first after the ARMX bit is set. Once a capture occurs, capture circuit 0 is disarmed, and capture circuit 1 is armed. After capture circuit 1 performs a capture, it is disarmed, and the ARMX bit is cleared. No further captures are performed until the ARMX bit is set again. If only one of the capture circuits is enabled, then a single capture occurs on the enabled capture circuit and the ARMX bit is then cleared.</p> |
| 0<br>ARMX     | <p>Arm X</p> <p>Setting this bit high starts the input capture process. This bit can be cleared at any time to disable input capture operation. This bit is self-cleared when in one shot mode and one or more of the enabled capture circuits has had a capture event.</p> <p>0b - Input capture operation is disabled.<br/>1b - Input capture operation as specified by CAPTCTRLX[EDGXx] is enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

### 31.5.35 Capture Compare X Register (SM2CAPTCOMPX)

#### Offset

| Register     | Offset |
|--------------|--------|
| SM2CAPTCOMPX | FEh    |

#### Function

Contains capture and control values for mode X. This register is write-protected by MCTRL2[WRPROT] bits.

**Diagram****Fields**

| Field           | Function                                                                                                                  |
|-----------------|---------------------------------------------------------------------------------------------------------------------------|
| 15-8<br>EDGCNTX | Edge Counter X<br>This field contains the edge counter value for the PWM_X input capture circuitry.                       |
| 7-0<br>EDGCMPX  | Edge Compare X<br>This field is the compare value associated with the edge counter for the PWM_X input capture circuitry. |

**31.5.36 Capture Value 0 Register (SM2CVAL0)****Offset**

| Register | Offset |
|----------|--------|
| SM2CVAL0 | 100h   |

**Function**

Writing this register generates bus transfer error.

**Diagram****Fields**

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                         |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0<br>CAPTVAL0 | Capture Value 0<br>This field stores the value captured from the submodule counter. Exactly when this capture occurs is defined by CAPTCTRLX[EDGX0]. Each capture increases the value of CAPTCTRLX[CX0CNT] by 1 until the maximum value is reached. Each read of this field decreases the value of CAPTCTRLX[CX0CNT] by 1 until 0 is reached. This field is not byte accessible. |

### 31.5.37 Capture Value 0 Cycle Register (SM2CVAL0CYC)

#### Offset

| Register    | Offset |
|-------------|--------|
| SM2CVAL0CYC | 102h   |

#### Function

Writing this register generates bus transfer error.

#### Diagram



#### Fields

| Field           | Function                                                                                                                                                                                                                      |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-4<br>—       | Reserved                                                                                                                                                                                                                      |
| 3-0<br>CVAL0CYC | Capture Value 0 Cycle<br><br>This field stores the cycle number corresponding to the value captured in CVAL0. This field is incremented each time the counter is loaded with the INIT value at the end of a PWM modulo cycle. |

### 31.5.38 Capture Value 1 Register (SM2CVAL1)

#### Offset

| Register | Offset |
|----------|--------|
| SM2CVAL1 | 104h   |

#### Function

Writing this register generates bus transfer error.

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|----------|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |   |   | CAPTVAL1 |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |   |   |          |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0        | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Fields**

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                    |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0<br>CAPTVAL1 | Capture Value 1<br><br>This field stores the value captured from the submodule counter when this capture occurs is defined by CAPTCTRLX[EDGX1]. Each capture increases the value of CAPTCTRLX[CX1CNT] by 1 until the maximum value is reached. Each read of this field decreases the value of CAPTCTRLX[CX1CNT] by 1 until 0 is reached. This field is not byte accessible. |

**31.5.39 Capture Value 1 Cycle Register (SM2CVAL1CYC)****Offset**

| Register    | Offset |
|-------------|--------|
| SM2CVAL1CYC | 106h   |

**Function**

Writing this register generates bus transfer error.

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2        | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|----------|---|---|
| R     |    |    |    |    |    |    |   |   | 0 |   |   |   |   | CVAL1CYC |   |   |
| W     |    |    |    |    |    |    |   |   |   |   |   |   |   |          |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0        | 0 | 0 |

**Fields**

| Field           | Function                                                                                                                                                                                                                                                               |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-4<br>—       | Reserved                                                                                                                                                                                                                                                               |
| 3-0<br>CVAL1CYC | Capture Value 1 Cycle<br><br>This field stores the cycle number corresponding to the value captured in CVAL1. This field is incremented each time the counter is loaded with the INIT value at the end of a PWM modulo cycle.<br><br>Resets to 0 at POR or hard reset. |

### 31.5.40 Output Enable Register (OUTEN)

#### Offset

| Register | Offset |
|----------|--------|
| OUTEN    | 180h   |

#### Function

Contains PWM output enables. This register is write-protected by MCTRL2[WRPROT] bits.

#### Diagram

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9       | 8 | 7 | 6 | 5       | 4 | 3 | 2       | 1 | 0 |
|-------|----|----|----|----|----|----|---------|---|---|---|---------|---|---|---------|---|---|
| R     | 0  |    |    |    | 0  |    |         |   | 0 |   |         |   | 0 |         |   |   |
| W     |    |    |    |    |    |    | PWMA_EN |   |   |   | PWMB_EN |   |   | PWMX_EN |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0 | 0 | 0 | 0       | 0 | 0 | 0       | 0 | 0 |

#### Fields

| Field           | Function                                                                                                                                                                                                                                                                                                     |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12<br>—      | Reserved                                                                                                                                                                                                                                                                                                     |
| 11<br>—         | Reserved                                                                                                                                                                                                                                                                                                     |
| 10-8<br>PWMA_EN | PWM_A Output Enables<br><br>This field enables the PWM_A outputs of submodules 2 - 0, respectively. Set these bits to 0 (output disabled) when a PWM_A pin is being used for input capture. <ul style="list-style-type: none"><li>• 0b0 PWM_A output disabled.</li><li>• 0b1 PWM_A output enabled.</li></ul> |
| 7<br>—          | Reserved                                                                                                                                                                                                                                                                                                     |
| 6-4<br>PWMB_EN  | PWM_B Output Enables<br><br>This field enables the PWM_B outputs of submodules 2 - 0, respectively. Set these bits to 0 (output disabled) when a PWM_B pin is being used for input capture. <ul style="list-style-type: none"><li>• 0b0 PWM_B output disabled.</li><li>• 0b1 PWM_B output enabled.</li></ul> |
| 3<br>—          | Reserved                                                                                                                                                                                                                                                                                                     |

Table continues on the next page...

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                                                                                                                      |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2-0<br>PWMX_EN | <p>PWM_X Output Enables</p> <p>This field enables the PWM_X outputs of submodules 2 - 0, respectively. Set these bits to 0 (output disabled) when a PWM_X pin is being used for input capture or deadtime correction.</p> <ul style="list-style-type: none"> <li>• 0b0 PWM_X output disabled.</li> <li>• 0b1 PWM_X output enabled.</li> </ul> |

### 31.5.41 Mask Register (MASK)

#### Offset

| Register | Offset |
|----------|--------|
| MASK     | 182h   |

#### Function

MASK is double buffered and does not take effect until a FORCE\_OUT event occurs within the appropriate submodule. Reading MASK reads the buffered values and not necessarily the values currently in effect. This double buffering can be overridden by setting the UPDATE\_MASK bits.

#### Diagram



#### Fields

| Field                    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>—                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 14-12<br>UPDATE_MAS<br>K | <p>Update Mask Bits Immediately</p> <p>This field masks or unmasks the PWM_X (X = A, B, or X) outputs of submodules 2 - 0 respectively by forcing the MASK* (* = A, B or X) bits to be immediately updated within submodules 2 - 0, respectively without waiting for a FORCE_OUT event. These self-clearing bits always read as zero. Software may write to any or all of these bits and may set these bits in the same write operation that updates the MASKA, MASKB, and MASKX fields of this register.</p> <ul style="list-style-type: none"> <li>• 0b0 Normal operation. MASK* bits within the corresponding submodule are not updated until a FORCE_OUT event occurs within the submodule.</li> </ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | <ul style="list-style-type: none"> <li>• 0b1 Immediate operation. MASK* bits within the corresponding submodule are updated on the following clock edge after setting this bit.</li> </ul> <p>For example:</p> <ul style="list-style-type: none"> <li>• UPDATE_MASK[3]=1 updates the mask bits MASKA[3], MASKB[3], and MASKX[3].</li> <li>• UPDATE_MASK[3:0]=0101 updates the mask bits MASKA[2], MASKA[0], MASKB[2], MASKB[0], MASKX[2], and MASKX[0].</li> </ul> |
| 11<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 10-8<br>MASKA | <p>PWM_A Masks</p> <p>This field masks the PWM_A outputs of submodules 2 - 0, respectively by forcing the output to logic 0 prior to consideration of the output polarity.</p> <ul style="list-style-type: none"> <li>• 0b0 PWM_A output normal.</li> <li>• 0b1 PWM_A output masked.</li> </ul> <p>MASKA[3:0] masks PWM_A_3 through PWM_A_0</p>                                                                                                                    |
| 7<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6-4<br>MASKB  | <p>PWM_B Masks</p> <p>This field masks the PWM_B outputs of submodules 2 - 0, respectively by forcing the output to logic 0 prior to consideration of the output polarity.</p> <ul style="list-style-type: none"> <li>• 0b0 PWM_B output normal.</li> <li>• 0b1 PWM_B output masked.</li> </ul> <p>MASKB[3:0] masks PWM_B_3 through PWM_B_0</p>                                                                                                                    |
| 3<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2-0<br>MASKX  | <p>PWM_X Masks</p> <p>This field masks the PWM_X outputs of submodules 2 - 0, respectively by forcing the output to logic 0 prior to consideration of the output polarity.</p> <ul style="list-style-type: none"> <li>• 0b0 PWM_X output normal.</li> <li>• 0b1 PWM_X output masked.</li> </ul> <p>MASKX[3:0] masks PWM_X_3 through PWM_X_0</p>                                                                                                                    |

### 31.5.42 Software Controlled Output Register (SWCOUT)

#### Offset

| Register | Offset |
|----------|--------|
| SWCOUT   | 184h   |

#### Function

These bits are double buffered and do not take effect until a FORCE\_OUT event occurs within the appropriate submodule. Reading these bits reads the buffered value and not necessarily the value currently in effect.

#### Diagram

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5            | 4            | 3            | 2            | 1            | 0            |
|-------|----|----|----|----|----|----|---|---|---|---|--------------|--------------|--------------|--------------|--------------|--------------|
| R     |    |    |    |    | 0  |    |   |   | 0 | 0 | SM2O<br>UT23 | SM2O<br>UT45 | SM1O<br>UT23 | SM1O<br>UT45 | SM0O<br>UT23 | SM0O<br>UT45 |
| W     |    |    |    |    |    |    |   |   |   |   | UT23         | UT45         | UT23         | UT45         | UT23         | UT45         |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0            | 0            | 0            | 0            | 0            | 0            |

#### Fields

| Field    | Function                                                                                                                                                                                                                                                                                                                                            |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-8     | Reserved                                                                                                                                                                                                                                                                                                                                            |
| —        |                                                                                                                                                                                                                                                                                                                                                     |
| 7        | Reserved                                                                                                                                                                                                                                                                                                                                            |
| —        |                                                                                                                                                                                                                                                                                                                                                     |
| 6        | Reserved                                                                                                                                                                                                                                                                                                                                            |
| —        |                                                                                                                                                                                                                                                                                                                                                     |
| 5        | Submodule 2 Software Controlled Output 23                                                                                                                                                                                                                                                                                                           |
| SM2OUT23 | This field is used when DTSRCSEL[SM2SEL23] is set to b10. It allows software control of which signal is supplied to the deadtime generator of that submodule.<br><br>0b - A logic 0 is supplied to the deadtime generator of submodule 2 instead of PWM23.<br>1b - A logic 1 is supplied to the deadtime generator of submodule 2 instead of PWM23. |
| 4        | Submodule 2 Software Controlled Output 45                                                                                                                                                                                                                                                                                                           |
| SM2OUT45 | This field is used when DTSRCSEL[SM2SEL45] is set to b10. It allows software control of which signal is supplied to the deadtime generator of that submodule.<br><br>0b - A logic 0 is supplied to the deadtime generator of submodule 2 instead of PWM45.<br>1b - A logic 1 is supplied to the deadtime generator of submodule 2 instead of PWM45. |
| 3        | Submodule 1 Software Controlled Output 23                                                                                                                                                                                                                                                                                                           |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SM1OUT23      | <p>This field is used when DTSRCSEL[SM1SEL23] is set to b10. It allows software control of which signal is supplied to the deadtime generator of that submodule.</p> <p>0b - A logic 0 is supplied to the deadtime generator of submodule 1 instead of PWM23.</p> <p>1b - A logic 1 is supplied to the deadtime generator of submodule 1 instead of PWM23.</p>                                                  |
| 2<br>SM1OUT45 | <p>Submodule 1 Software Controlled Output 45</p> <p>This field is used when DTSRCSEL[SM1SEL45] is set to b10. It allows software control of which signal is supplied to the deadtime generator of that submodule.</p> <p>0b - A logic 0 is supplied to the deadtime generator of submodule 1 instead of PWM45.</p> <p>1b - A logic 1 is supplied to the deadtime generator of submodule 1 instead of PWM45.</p> |
| 1<br>SM0OUT23 | <p>Submodule 0 Software Controlled Output 23</p> <p>This field is used when DTSRCSEL[SM0SEL23] is set to b10. It allows software control of which signal is supplied to the deadtime generator of that submodule.</p> <p>0b - A logic 0 is supplied to the deadtime generator of submodule 0 instead of PWM23.</p> <p>1b - A logic 1 is supplied to the deadtime generator of submodule 0 instead of PWM23.</p> |
| 0<br>SM0OUT45 | <p>Submodule 0 Software Controlled Output 45</p> <p>This field is used when DTSRCSEL[SM0SEL45] is set to b10. It allows software control of which signal is supplied to the deadtime generator of that submodule.</p> <p>0b - A logic 0 is supplied to the deadtime generator of submodule 0 instead of PWM45.</p> <p>1b - A logic 1 is supplied to the deadtime generator of submodule 0 instead of PWM45.</p> |

### 31.5.43 PWM Source Select Register (DTSRCSEL)

#### Offset

| Register | Offset |
|----------|--------|
| DTSRCSEL | 186h   |

#### Function

The PWM source select bits are double buffered and do not take effect until a FORCE\_OUT event occurs within the appropriate submodule. Reading these bits reads the buffered value and not necessarily the value currently in effect. This register is write-protected by MCTRL2[WRPROT] bits.

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11       | 10 | 9        | 8 | 7        | 6 | 5        | 4 | 3        | 2 | 1        | 0 |
|-------|----|----|----|----|----------|----|----------|---|----------|---|----------|---|----------|---|----------|---|
| R     | 0  | 0  |    |    | SM2SEL23 |    | SM2SEL45 |   | SM1SEL23 |   | SM1SEL45 |   | SM0SEL23 |   | SM0SEL45 |   |
| W     |    |    |    |    | 0        | 0  | 0        | 0 | 0        | 0 | 0        | 0 | 0        | 0 | 0        |   |
| Reset | 0  | 0  | 0  | 0  | 0        | 0  | 0        | 0 | 0        | 0 | 0        | 0 | 0        | 0 | 0        | 0 |

**Fields**

| Field             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-14<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 13-12<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 11-10<br>SM2SEL23 | <p>Submodule 2 PWM23 Control Select</p> <p>This field selects possible overrides to the generated SM2PWM23 signal that passes to the deadtime logic upon the occurrence of a FORCE_OUT event in that submodule.</p> <p>00b - Generated SM2PWM23 signal used by the deadtime logic.<br/>     01b - Inverted generated SM2PWM23 signal used by the deadtime logic.<br/>     10b - SWCOUT[SM2OUT23] used by the deadtime logic.<br/>     11b - PWM2_EXTA signal used by the deadtime logic.</p> |
| 9-8<br>SM2SEL45   | <p>Submodule 2 PWM45 Control Select</p> <p>This field selects possible overrides to the generated SM2PWM45 signal that passes to the deadtime logic upon the occurrence of a FORCE_OUT event in that submodule.</p> <p>00b - Generated SM2PWM45 signal used by the deadtime logic.<br/>     01b - Inverted generated SM2PWM45 signal used by the deadtime logic.<br/>     10b - SWCOUT[SM2OUT45] used by the deadtime logic.<br/>     11b - Reserved</p>                                     |
| 7-6<br>SM1SEL23   | <p>Submodule 1 PWM23 Control Select</p> <p>This field selects possible overrides to the generated SM1PWM23 signal that passes to the deadtime logic upon the occurrence of a FORCE_OUT event in that submodule.</p> <p>00b - Generated SM1PWM23 signal used by the deadtime logic.<br/>     01b - Inverted generated SM1PWM23 signal used by the deadtime logic.<br/>     10b - SWCOUT[SM1OUT23] used by the deadtime logic.<br/>     11b - PWM1_EXTA signal used by the deadtime logic.</p> |
| 5-4               | Submodule 1 PWM45 Control Select                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SM1SEL45        | <p>This field selects possible overrides to the generated SM1PWM45 signal that passes to the deadtime logic upon the occurrence of a FORCE_OUT event in that submodule.</p> <p>00b - Generated SM1PWM45 signal used by the deadtime logic.<br/>     01b - Inverted generated SM1PWM45 signal used by the deadtime logic.<br/>     10b - SWCOUT[SM1OUT45] used by the deadtime logic.<br/>     11b - Reserved</p>                                                                             |
| 3-2<br>SM0SEL23 | <p>Submodule 0 PWM23 Control Select</p> <p>This field selects possible overrides to the generated SM0PWM23 signal that passes to the deadtime logic upon the occurrence of a FORCE_OUT event in that submodule.</p> <p>00b - Generated SM0PWM23 signal used by the deadtime logic.<br/>     01b - Inverted generated SM0PWM23 signal used by the deadtime logic.<br/>     10b - SWCOUT[SM0OUT23] used by the deadtime logic.<br/>     11b - PWM0_EXTA signal used by the deadtime logic.</p> |
| 1-0<br>SM0SEL45 | <p>Submodule 0 PWM45 Control Select</p> <p>This field selects possible overrides to the generated SM0PWM45 signal that passes to the deadtime logic upon the occurrence of a FORCE_OUT event in that submodule.</p> <p>00b - Generated SM0PWM45 signal used by the deadtime logic.<br/>     01b - Inverted generated SM0PWM45 signal used by the deadtime logic.<br/>     10b - SWCOUT[SM0OUT45] used by the deadtime logic.<br/>     11b - Reserved</p>                                     |

### 31.5.44 Master Control Register (MCTRL)

#### Offset

| Register | Offset |
|----------|--------|
| MCTRL    | 188h   |

#### Function

In every 4-bit field in this register, each bit acts on a separate submodule. Accordingly, the description of every bit field refers to the effect of an individual bit.

**Diagram**

| Bits  | 15 | 14   | 13 | 12 | 11 | 10  | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2    | 1 | 0 |
|-------|----|------|----|----|----|-----|---|---|---|---|---|---|---|------|---|---|
| R     | 0  | IPOL |    |    | 0  | RUN |   |   | 0 | 0 | 0 | 0 | 0 | LDOK |   |   |
| W     |    |      |    |    |    |     |   |   |   |   |   |   |   |      |   |   |
| Reset | 0  | 0    | 0  | 0  | 0  | 0   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0    | 0 | 0 |

**Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 14-12<br>IPOL | <p>Current Polarity</p> <p>This field corresponds to submodules 2 - 0, respectively. Each bit selects between PWM23 and PWM45 as the source for the generation of the complementary PWM pair output for the corresponding submodule. MCTRL[IPOL] is ignored in independent mode.</p> <p>MCTRL[IPOL] does not take effect until a FORCE_OUT event takes place in the appropriate submodule. Reading MCTRL[IPOL] reads the buffered value and not necessarily the value currently in effect.</p> <p>000b - PWM23 is used to generate complementary PWM pair in the corresponding submodule.</p> <p>001b - PWM45 is used to generate complementary PWM pair in the corresponding submodule.</p> |
| 11<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 10-8<br>RUN   | <p>Run</p> <p>This field enables the clocks to the PWM generator of submodules 2 - 0, respectively. The corresponding MCTRL[RUN] bit must be set for each submodule that is using its input capture functions or is using the local reload as its reload source. When this bit equals zero, the submodule counter is reset, and PWM outputs are held. A reset clears this field.</p> <p>000b - PWM counter is stopped, but PWM outputs hold the current state.</p> <p>001b - PWM counter is started in the corresponding submodule.</p>                                                                                                                                                      |
| 7<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 6-4<br>CLDOK  | <p>Clear Load Okay</p> <p>This field corresponds to submodules 2 - 0, respectively. Each write-only bit is used to clear the corresponding bit of MCTRL[LDOK]. Write a 1 to CLDOK to clear the corresponding MCTRL[LDOK] bit. If a reload occurs within a submodule with the corresponding MCTRL[LDOK] bit set at the same time that MCTRL[CLDOK] is written, then the reload in that submodule will not be performed and MCTRL[LDOK] will be cleared. CLDOK bit is self-clearing and always reads as a 0.</p>                                                                                                                                                                               |
| 3<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2-0<br>LDOK | <p>Load Okay</p> <p>This field corresponds to submodules 2 - 0, respectively. Each read/set bit loads CTRL[PRSC] and the INIT, FRACVALx, and VALx registers of the corresponding submodule into a set of buffers. The buffered prescaler divisor, submodule counter modulus value, and PWM pulse width take effect at the next PWM reload if CTRL[LDMOD] is clear or if CTRL[LDMOD] is set. Set the corresponding MCTRL[LDOK] bit by reading it when it is logic zero and then writing a logic one to it. The VALx, FRACVALx, INIT, and CTRL[PRSC] registers of the corresponding submodule cannot be written while the corresponding MCTRL[LDOK] bit is set.</p> <p>In Master Reload Mode (CTRL2[RELOAD_SEL]=1), it is necessary to set the LDOK bit corresponding to submodule0; however, it is recommended to also set the LDOK bit of the slave submodules, to prevent unwanted writes to the registers in the slave submodules.</p> <p>The MCTRL[LDOK] bit is automatically cleared after the new values are loaded, or it can be manually cleared before a reload by writing a logic 1 to the appropriate MCTRL[CLDOK] bit. LDOK bits cannot be written with a zero. MCTRL[LDOK] can be set in DMA mode when the DMA indicates that it has completed the update of all CTRL[PRSC], INIT, FRACVALx, and VALx registers in the corresponding submodule. Reset clears LDOK field.</p> <p>000b - Do not load new values.<br/>001b - Load prescaler, modulus, and PWM values of the corresponding submodule.</p> |

### 31.5.45 Master Control 2 Register (MCTRL2)

#### Offset

| Register | Offset |
|----------|--------|
| MCTRL2   | 18Ah   |

#### Function

Includes control for monitoring the PLL state and write protection of some configuration registers.

#### Diagram



#### Fields

| Field | Function |
|-------|----------|
| 15-8  | Reserved |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7-6<br>STRETCH_CN<br>T_PRSC | <p>Stretch IPBus clock count prescaler for mux0_trig/mux1_trig/out0_trig/out1_trig/pwma_trig/pwmb_trig</p> <p>If user config eFlexPWM work in fast clk mode(use SoC level register, eFlexPWM input signal fast_clk_mode is high), then user can use these bits to stretch output signals mux0_trig/mux1_trig/out0_trig/out1_trig/pwma_trig/pwmb_trig.</p> <p>00b - Stretch count is zero, no stretch.</p> <p>01b - Stretch mux0_trig/mux1_trig/out0_trig/out1_trig/pwma_trig/pwmb_trig for 2 IPBus clock period.</p> <p>10b - Stretch mux0_trig/mux1_trig/out0_trig/out1_trig/pwma_trig/pwmb_trig for 4 IPBus clock period.</p> <p>11b - Stretch mux0_trig/mux1_trig/out0_trig/out1_trig/pwma_trig/pwmb_trig for 8 IPBus clock period.</p> |
| 5-4<br>—                    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3-2<br>WRPROT               | <p>Write protect</p> <p>Enable write protection of some configuration registers of eFlexPWM.</p> <p>00b - Write protection off (default).</p> <p>01b - Write protection on.</p> <p>10b - Write protection off and locked until chip reset.</p> <p>11b - Write protection on and locked until chip reset.</p>                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1-0<br>—                    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

### 31.5.46 Fault Control Register (FCTRL0)

#### Offset

| Register | Offset |
|----------|--------|
| FCTRL0   | 18Ch   |

#### Function

For every 4-bit field in this register, the bits act on the fault inputs in order. For example, FLVL bits 15-12 act on faults 3-0, respectively. This register is write-protected by MCTRL2[WRPROT] bits.

**Diagram**

| Bits  | 15   | 14 | 13 | 12 | 11    | 10 | 9 | 8 | 7     | 6 | 5 | 4 | 3   | 2 | 1 | 0 |
|-------|------|----|----|----|-------|----|---|---|-------|---|---|---|-----|---|---|---|
| R     | FLVL |    |    |    | FAUTO |    |   |   | FSAFE |   |   |   | FIE |   |   |   |
| Reset | 0    | 0  | 0  | 0  | 0     | 0  | 0 | 0 | 0     | 0 | 0 | 0 | 0   | 0 | 0 | 0 |

**Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12<br>FLVL | <p>Fault Level</p> <p>This field selects the active logic level of the individual fault inputs 3-0, respectively. A reset clears this field.</p> <p>0000b - A logic 0 on the fault input indicates a fault condition.</p> <p>0001b - A logic 1 on the fault input indicates a fault condition.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 11-8<br>FAUTO | <p>Automatic Fault Clearing</p> <p>This field selects automatic or manual clearing of faults 3-0, respectively. A reset clears this field.</p> <p>0000b - Manual fault clearing. PWM outputs disabled by this fault are not enabled until FSTS[FFLAGx] is clear at the start of a half cycle or full cycle depending on the states of FSTS[FHALF] and FSTS[FFULL]. If neither FFULL nor FHALF is set, then the fault condition cannot be cleared. This is further controlled by FCTRL[FSAFE].</p> <p>0001b - Automatic fault clearing. PWM outputs disabled by this fault are enabled when FSTS[FFPINx] is clear at the start of a half cycle or full cycle depending on the states of FSTS[FHALF] and FSTS[FFULL] without regard to the state of FSTS[FFLAGx]. If neither FFULL nor FHALF is set, then the fault condition cannot be cleared.</p>                                                                                                                                                                                                                                                                                                                                |
| 7-4<br>FSAFE  | <p>Fault Safety Mode</p> <p>This field selects the safety mode during manual fault clearing. A reset clears this field.</p> <p>FSTS[FFPINx] may indicate that a fault condition still exists even though the actual fault signal at the FAULTx pin is clear due to the fault filter latency.</p> <p>0000b - Normal mode. PWM outputs disabled by this fault are not enabled until FSTS[FFLAGx] is clear at the start of a half cycle or full cycle depending on the states of FSTS[FHALF] and FSTS[FFULL] without regard to the state of FSTS[FFPINx]. If neither FHALF nor FFULL is set, then the fault condition cannot be cleared. The PWM outputs disabled by this fault input will not be re-enabled until the actual FAULTx input signal de-asserts since the fault input will combinationally disable the PWM outputs (as programmed in DISMAPn).</p> <p>0001b - Safe mode. PWM outputs disabled by this fault are not enabled until FSTS[FFLAGx] is clear and FSTS[FFPINx] is clear at the start of a half cycle or full cycle depending on the states of FSTS[FHALF] and FSTS[FFULL]. If neither FHALF nor FFULL is set, then the fault condition cannot be cleared.</p> |
| 3-0<br>FIE    | <p>Fault Interrupt Enables</p> <p>This field enables CPU interrupt requests generated by the FAULTx pins. A reset clears this field.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                             |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <p style="text-align: center;"><b>NOTE</b></p> <p>The fault protection circuit is independent of the FIEx bit and is always active. If a fault is detected, the PWM outputs are disabled according to the disable mapping register.</p> <p>0000b - FAULTx CPU interrupt requests disabled.</p> <p>0001b - FAULTx CPU interrupt requests enabled.</p> |

### 31.5.47 Fault Status Register (FSTS0)

#### Offset

| Register | Offset |
|----------|--------|
| FSTS0    | 18Eh   |

#### Function

Includes controls related to fault conditions.

#### Diagram



#### Fields

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12<br>FHALF | <p>Half Cycle Fault Recovery</p> <p>This field is used to control the timing for re-enabling the PWM outputs after a fault condition. These bits apply to both automatic and manual clearing of a fault condition. These register bits are write-protected by MCTRL2[WRPROT] bits.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>Both FHALF and FFULL can be set so that the fault recovery occurs at the start of a full cycle and at the start of a half cycle (as defined by VAL0). If neither FHALF nor FFULL is set, then no fault recovery is possible.</p> <p>0000b - PWM outputs are not re-enabled at the start of a half cycle.</p> <p>0001b - PWM outputs are re-enabled at the start of a half cycle (as defined by VAL0).</p> |
| 11-8           | Filtered Fault Pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FFPIN        | <p>These read-only bits reflect the current state of the filtered FAULTx pins converted to high polarity. A logic 1 indicates that a fault condition exists on the filtered FAULTx pin. A reset has no effect on this field.</p> <p>After the system reset de-asserts, these are the possible values of FFPIN:</p> <ul style="list-style-type: none"> <li>If FCTRL[FLVL] = 0 and FAULTx = 0, then FFPIN is set to 1.</li> <li>If FCTRL[FLVL] = 0 and FAULTx = 1, then FFPIN is kept as 0.</li> <li>If FCTRL[FLVL] = 1 and FAULTx = 0, then FFPIN is kept as 0.</li> <li>If FCTRL[FLVL] = 1 and FAULTx = 1, then FFPIN is set to 1.</li> </ul>                                                                                                                                                                                             |
| 7-4<br>FFULL | <p>Full Cycle</p> <p>This field is used to control the timing for re-enabling the PWM outputs after a fault condition. These bits apply to both automatic and manual clearing of a fault condition. These register bits are write-protected by MCTRL2[WRPROT] bits.</p> <p><b>NOTE</b></p> <p>Both FHALF and FFULL can be set so that the fault recovery occurs at the start of a full cycle and at the start of a half cycle (as defined by VAL0). If neither FHALF nor FFULL is set, then no fault recovery is possible.</p> <p>0000b - PWM outputs are not re-enabled at the start of a full cycle<br/>0001b - PWM outputs are re-enabled at the start of a full cycle</p>                                                                                                                                                             |
| 3-0<br>FFLAG | <p>Fault Flags</p> <p>These read-only flags are set within two CPU cycles after a transition to active on the FAULTx pin. Clear this bit by writing a logic one to it. A reset clears this field. While the reset value is 0, these bits may be set to 1 by the time they can be read depending on the state of the fault input signals.</p> <p>After the system reset de-asserts, these are the possible values of FFLAG:</p> <ul style="list-style-type: none"> <li>If FCTRL[FLVL] = 0 and FAULTx = 0, then FFLAG is set to 1.</li> <li>If FCTRL[FLVL] = 0 and FAULTx = 1, then FFLAG is kept as 0.</li> <li>If FCTRL[FLVL] = 1 and FAULTx = 0, then FFLAG is kept as 0.</li> <li>If FCTRL[FLVL] = 1 and FAULTx = 1, then FFLAG is set to 1.</li> </ul> <p>0000b - No fault on the FAULTx pin.<br/>0001b - Fault on the FAULTx pin.</p> |

### 31.5.48 Fault Filter Register (FFILT0)

#### Offset

| Register | Offset |
|----------|--------|
| FFILT0   | 190h   |

## Function

The settings in this register are shared among each of the fault input filters within the fault channel.

Input filter considerations include:

- Set the FILT\_PER value such that the sampling period is larger than the period of the expected noise. This way a noise spike corrupts one sample. Select the FILT\_CNT value to reduce and recognize the probability of noisy samples causing an incorrect transition. The probability of an incorrect transition is defined as the probability of an incorrect sample raised to the FILT\_CNT+3 power.
- The values of FILT\_PER and FILT\_CNT must be traded off against the desire for minimal latency in recognizing input transitions. Turning on the input filter (setting FILT\_PER to a non-zero value) introduces a latency of ((FILT\_CNT+4) x FILT\_PER x IPBus clock period).

### NOTE

When the filter is enabled, there is a combinational path to disable the PWM outputs to ensure rapid response to fault conditions, and fault response if the PWM module loses its clock. The latency induced by the filter will be seen in the time to set FSTS[FFLAG] and FSTS[FFPIN].

This register is write-protected by MCTRL2[WRPROT] bits.

## Diagram

| Bits  | 15   | 14 | 13 | 12 | 11 | 10       | 9 | 8 | 7 | 6        | 5 | 4 | 3 | 2 | 1 | 0 |   |
|-------|------|----|----|----|----|----------|---|---|---|----------|---|---|---|---|---|---|---|
| R     | GSTR | 0  |    |    |    | FILT_CNT |   |   |   | FILT_PER |   |   |   |   |   |   |   |
| W     |      |    |    |    |    |          |   |   |   |          |   |   |   |   |   |   |   |
| Reset | 0    | 0  | 0  | 0  | 0  | 0        | 0 | 0 | 0 | 0        | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

## Fields

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>GSTR       | Fault Glitch Stretch Enable<br><br>This field is used to enable the fault glitch-stretching logic. This logic ensures that narrow fault glitches are stretched to be at least 2 IPBus clock cycles wide. In some cases, a narrow fault input can cause problems due to the short PWM output shutdown/re-activation time. The stretching logic ensures that a glitch on the fault input, when the fault filter is disabled, will be registered in the fault flags.<br><br>0b - Fault input glitch stretching is disabled.<br>1b - Input fault signals are stretched to at least 2 IPBus clock cycles. |
| 14-11<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 10-8<br>FILT_CNT | Fault Filter Count<br><br>These bits represent the number of consecutive samples that must agree prior to the input filter accepting an input transition. The number of samples is the decimal value of this field plus three: the bit field value of 0-7 represents 3-10 samples, respectively. The value of FILT_CNT affects the input latency.                                                                                                                                                                                                                                                    |
| 7-0<br>FILT_PER  | Fault Filter Period<br><br>This 8-bit field applies universally to all fault inputs.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

Table continues on the next page...

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <p>These bits represent the sampling period (in IPBus clock cycles) of the fault pin input filter. Each input is sampled multiple times at the rate specified by this field. If FILT_PER is 0x00 (default), then the input filter is bypassed. The value of FILT_PER affects the input latency.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>When changing values for FILT_PER from one non-zero value to another non-zero value, first write a value of zero to clear the filter.</p> |

### 31.5.49 Fault Test Register (FTST0)

#### Offset

| Register | Offset |
|----------|--------|
| FTST0    | 192h   |

#### Function

Contains FTEST field for fault simulation.

#### Diagram



#### Fields

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-1<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0<br>FTEST | <p>Fault Test</p> <p>This field is used to simulate a fault condition. Setting this bit causes a simulated fault to be sent into all of the fault filters. The condition propagates to the fault flags and possibly the PWM outputs depending on the DISMAPn settings. Clearing this bit removes the simulated fault condition. This register bit is write-protected by MCTRL2[WRPROT] bits.</p> <p>0b - No fault<br/>1b - Cause a simulated fault</p> |

### 31.5.50 Fault Control 2 Register (FCTRL20)

#### Offset

| Register | Offset |
|----------|--------|
| FCTRL20  | 194h   |

#### Function

Controls combinational link from fault inputs to PWM outputs. This register is write-protected by MCTRL2[WRPROT] bits.

#### Diagram



#### Fields

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-4<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3-0<br>NOCOMB | <p><b>No Combinational Path From Fault Input To PWM Output</b></p> <p>This field is used to control the combinational path from the fault inputs to the PWM outputs. When these bits are low (default), the corresponding fault inputs have a combinational path to the PWM outputs that are sensitive to these fault inputs (as defined by DISMAP0). This combinational path is a safety feature that ensures the output is disabled even if the SOC has a failure of its clocking system. The combinational path also means that a pulse on the fault input can cause a brief disable of the PWM output even if the fault pulse is not wide enough to get through the input filter and be latched in the fault logic. Setting these bits removes the combinational path and uses the filtered and latched fault signals as the fault source to disable the PWM outputs. This eliminates fault glitches from creating PWM output glitches but also increases the latency to respond to a real fault.</p> <p>0000b - There is a combinational link from the fault inputs to the PWM outputs. The fault inputs are combined with the filtered and latched fault signals to disable the PWM outputs.</p> <p>0001b - The direct combinational path from the fault inputs to the PWM outputs is disabled and the filtered and latched fault signals are used to disable the PWM outputs.</p> |

# Chapter 32

## Quadrature Decoder (QDC)

### 32.1 Chip-specific QDC information

Table 174. Reference links to related information

| Topic                | Related module | Reference                                     |
|----------------------|----------------|-----------------------------------------------|
| Full description     | QDC            | <a href="#">QDC</a>                           |
| System memory map    |                | <a href="#">Memory map</a>                    |
| Clocking             |                | <a href="#">Clock distribution</a>            |
| Power Management     |                | <a href="#">Power Management</a>              |
| Signal multiplexing  | Port control   | <a href="#">Signal multiplexing</a>           |
| Peripheral Input Mux | INPUTMUX       | <a href="#">Peripheral Input multiplexing</a> |

#### 32.1.1 Module instances

This device has one instance of the QDC module, QDC0.

#### 32.1.2 Peripheral interconnections

This module provides interfacing capability to position/speed sensors used in industrial motor control applications. It has five input signals: PHASEA, PHASEB, INDEX, TRIGGER, and HOME. This module is used to decode shaft position, revolution count and speed.

See the attached Peripheral Mux Assignments spreadsheet for details.

### 32.2 Overview

eQDC does the following:

- Interfaces to position or speed sensors that are used in industrial motor control applications.
- Decodes shaft position, revolution count, and speed.

eQDC receives the following 8 input signals from position or speed sensors:

- PHASEA
- PHASEB
- INDEX/PRESET
- TRIGGER
- HOME/ENABLE
- ICAP[3:1]

eQDC outputs the following 11 signals for system use:

- POS\_MATCH[3:0]
- COMP\_FLG[3:0]
- DIR
- CNT\_DN

- CNT\_UP

**NOTE**

For eQDC, "asserted" indicates an output of 1 and "de-asserted" indicates an output of 0.

### 32.2.1 Block diagram

This is the block diagram of eQDC.



Figure 128. Block diagram

### 32.2.2 Features

- Logic to decode quadrature signals
- Configurable digital filters for inputs (these filters can be bypassed)
- 32-bit position counter capable of modulo counting
- Position counter that can be initialized by software or external events
- 16-bit position difference register
- Compare function that can indicate when shaft has reached a defined position
- A watchdog timer that can detect a non-rotating shaft condition
- Preloadable 16-bit revolution counter
- Maximum count frequency equals the peripheral clock rate
- Configurable interrupt when both PHASEA and PHASEB inputs change in the same cycle

## 32.3 Functional description

The following timing diagram shows the basic operation of an incremental position quadrature decoder.



Figure 129. Quadrature decoder signals

### 32.3.1 Positive versus negative direction

A typical quadrature encoder has 3 outputs: PHASEA signal, PHASEB signal, INDEX pulse (not shown).

- If PHASEA leads PHASEB, then motion is in the positive direction.
- If PHASEA trails PHASEB, then motion is in the negative direction.

Transitions on these phases can be integrated to yield position or differentiated to yield velocity. The quadrature decoder is designed to perform these functions in hardware.

### 32.3.2 Speed measurement

For applications with a fast-moving shaft encoder, the speed can be measured using either of the following methods:

- calculating the change in the position counter per unit time
- reading the position difference counter register

For applications with low motor speeds and low-line count quadrature encoders, the timer module enables high-resolution speed measurement by calculating the time intervals between quadrature phases.

- The timer module uses a 16-bit free running counter operated from a prescaled version of the peripheral clock.
- The prescaler FILT[PRSC] divides the peripheral clock by values ranging from 1 to 32768. A 100 MHz peripheral clock frequency would yield a resolution of from 10 ns to 327.68 µs and a maximum count period of from 0.65535 ms to 21474.5 ms. For example, with a 1000-tooth decoder, speeds could be calculated down to 0.0007 rpm using a prescaler.

### 32.3.3 Glitch filter

Because the quadrature decoder logic must sense signal transitions, the signal inputs are first run through a glitch filter. This glitch filter has a digital delay line, which samples multiple time points on the signal and verifies a stable new signal state before outputting this new signal state to the internal quadrature decoder logic. To adapt to a variety of signal bandwidths, the sample rate of this delay line is programmable.

### 32.3.4 Edge detect state machine

The Edge detect state machine looks for changes in the 4 possible states of the filtered PHASEA and PHASEB input signals. Direction of motion is calculated using these changes. Direction of motion is formatted as Count\_Up and Count\_Down signals. These signals are routed into up to 3 up/down counters:

- Position counter
- Revolution counter
- Position difference counter

### 32.3.5 Counter registers, and hold registers and how to initialize

When any of the counter registers is read, the contents of this counter register is written to the corresponding hold register. Taking a snapshot of the counters' values allows a consistent view of a system's position and the speed to be attained. If CTRL2[PMEN] is set, the position difference hold register is only updated when the position difference counter register is read. To capture a time stamp of when these registers are read, use the POS\_MATCH output with a timer channel.

#### 32.3.5.1 Position counter (POS)

POS counts up (upper position counter, UPOS) or down (lower position counter, LPOS) on every count pulse generated by the position difference of PHASEA and PHASEB input signals. POS acts as an integration\_info, whose count value is proportional to position. De-assertion of ENABLE pin stops the operation of POS. POS is initialized when any of the following conditions is met:

- If CTRL2[INITPOS] is set, a positive edge of TRIGGER input occurs.
- A write to CTRL[SWIP]
- If CTRL2[OPMODE] is cleared and CTRL[XIP] is set to 1, INDEX signal transition occurs
- If CTRL2[OPMODE] is cleared and CTRL[HIP] is set to 1, HOME signal transition occurs
- If CTRL2[OPMODE] is set, a positive edge of PRESET signal occurs.
- Position counter roll-over and roll-under

POS can be initialized to initial register if CTRL[REV]=0 and initialized to modulus register if CTRL[REV]=1, but if CTRL2[EMIP]=1 and INDEX signal transition initiates POS, POS is initialized under the circumstances listed in the following table:

|                                          | CTRL[XNE] = 0                        | CTRL[XNE] = 1                        | CTRL[REV] = 0                    | CTRL[REV] = 1                    |
|------------------------------------------|--------------------------------------|--------------------------------------|----------------------------------|----------------------------------|
| PHASEA leads<br>PHASEB (Clockwise)       | positive edge of INDEX<br>resets POS | negative edge of INDEX<br>resets POS | POS is reset to<br>initial value | POS is reset to<br>modulus value |
| PHASEA lags PASEHB<br>(Counterclockwise) | negative edge of INDEX<br>resets POS | positive edge of INDEX<br>resets POS | POS is reset to<br>modulus value | POS is reset to<br>initial value |

The INDEX and HOME signals can be programmed to interrupt the processor. When UPOS or LPOS is read, a snapshot of each of the following counter registers is placed into the corresponding hold register:

- position counter register
- If CTRL2[PMEN] is cleared, position difference counter register
- revolution counter register

#### 32.3.5.2 Position counter hold (POSH)

POSH stores a copy of POS when POS is read.

When POS is initialized by any event, the contents of POS are also copied into POSH. Meanwhile, count direction flag IOMR[DIR] is copied into count direction flag hold IOMR[DIRH]. When CTRL2[UPDHLD] is set to 1, the rising edge of TRIGGER input takes a snapshot of POS and stores it in UPOSH or LPOS.

Beside taking snapshot of POS counter by positive transient of TRIGGER input, 3 more signals are added to take snapshot of POS counter:

- Positive transition of ICAP[3] input can take snapshot of POS counter into UPOSH3/LPOS3
- Positive transition of ICAP[2] input can take snapshot of POS counter into UPOSH2/LPOS2
- Positive transition of ICAP[1] input can take snapshot of POS counter into UPOSH1/LPOS1

Note: This is used for an error checking mechanism to check of the position counter accumulated the correct number of counts between the same event. As example, the 1024-line incremental encoder must count 4096 counts when moving in the same direction between the index.

### 32.3.5.3 Position difference counter (POSD)

POSD contains the position difference value occurring between each read of the position register. The position register counts up or down on every count pulse. The position difference counter acts as a differentiator, whose count value is proportional to the change in position since the last time the position counter was read.

POSD is cleared when any of the following conditions is met:

- If CTRL2[PMEN] is cleared, when POS, POSD, or REV register is read, POSD is cleared and its contents are copied into POSDH.
- If CTRL2[PMEN] is cleared, positive edge of TRIGGER input occurs when CTRL2[UPDPOS] is set
- If CTRL2[PMEN] is set, when POSD is read.
- If CTRL2[PMEN] is set, positive edge of TRIGGER input occurs when CTRL2[UPDHLD] is set.

### 32.3.5.4 Position difference counter hold (POSDH)

POSDH takes and stores a snapshot of POSD. The snapshot is taken when any of the following conditions is met:

- If CTRL2[PMEN] is cleared, when POS, POSD, or REV register is read.
- When POSD is read (no matter CTRL2[PMEN] is clear or set).
- If CTRL2[UPDHLD] is set, a positive edge of the TRIGGER input occurs (no matter CTRL2[PMEN] is cleared or set).

### 32.3.5.5 Revolution counter (REV)

REV counts or integrates revolutions by counting index pulses. The direction of the count is determined by PHASEA and PHASEB input signals. A different count direction on the rising and falling edges of the index pulse indicates that eQDC changed direction on the index pulse. If CTRL2[OPMODE] is set, de-assertion of ENABLE input signal stops the operation of REV and PRESET signal transition initializes revolution counter to zero.

### 32.3.5.6 Revolution counter hold (REVH)

REVH takes a snapshot of REV when either of the following conditions is met:

- When POS, POSD, or REV register is read.
- If CTRL2[UPDHLD] is set, when a positive edge of the TRIGGER input signal occurs.

### 32.3.5.7 Watchdog timer (WDG)

WDG ensures that the algorithm is indicating motion in the shaft; 2 successive counts indicate proper operation and resets the timer. If CTRL2[OPMODE] is set, PRESET signal transition initializes WDG r to zero, and de-assertion of ENABLE input stops the operation of the WDG.

- The timeout value is programmable.
- When a timeout occurs, an interrupt to the processor can be generated.

### 32.3.5.8 Last edge time counter (LASTEDGE)

LASTEDGE contains the time since the last edge on PHASEA or PHASEB. The last edge time counter counts up on every prescaled clock pulse.

When POSD is read, contents in LASTEDGE are copied into LASTEDGEH.

### 32.3.5.9 Position difference period counter (POSDPER)

POSDPER contains the accumulated time from the last time the position difference counter was read. It counts up on every prescaled clock pulse and is loaded from the last edge time counter when POSD is read.

### 32.3.6 Double-set registers loading operation

The following registers are double-set (namely outer or inner-set), which enables them to be re-configured when eQDC is operating:

- Compare registers (UCOMP0/LCOMP0, UCOMP1/LCOMP1, UCOMP2/LCOMP2, UCOMP3/LCOMP3)
- Initial registers (UINIT/LINIT)
- Modulus registers (UMOD/LMOD)

After a value is written to one of these registers, the value is "buffered" into outer-set registers temporarily. Values will be loaded into inner-set registers and take effect using the following two methods:

- If CTRL2[LDMODE] is set to 1, "buffered" values are loaded into inner-set and take effect at the next roll-over or roll-under if CTRL[LDOKE] is set.
- If CTRL2[LDMODE] is set to 0, "buffered" values are loaded into inner-set and take effect immediately when CTRL[LDOKE] is set.

The double-set registers can be configured manually or automatically.

To configure the double-set registers manually:

1. Initialize the double-set registers:
  - a. Set CTRL2[LDMODE] to 0.
  - b. Clear CTRL[LDOKE] if it is not 0.
  - c. Write values into double-set registers, so the values are "buffered" into outer-set registers.
  - d. Set CTRL[LDOKE] to 1.
  - e. Wait for CTRL[LDOKE] to become 0, which means the values have been loaded into inner-set registers.
  - f. Change CTRL2[LDMODE] value as desired.
2. Update the double-set registers:
  - a. Clear CTRL[LDOKE] if it is not 0.
  - b. Write values into double-set registers, so the values are "buffered" into outer-set registers.
  - c. Set CTRL[LDOKE] to 1. When the values are loaded into inner-set registers, CTRL[LDOKE] is cleared automatically.
  - d. Go back to step a for iteration.

To configure the double-set registers automatically:

1. Initialize the double-set registers:
  - a. Set CTRL2[LDMODE] to 0.
  - b. Clear CTRL[LDOKE] if it is not 0.
  - c. Write values into double-set registers, so the values are "buffered" into outer-set registers.
  - d. Set CTRL[LDOKE] to 1.
  - e. Wait for CTRL[LDOKE] to become 0, which means the values have been loaded into inner-set registers.
  - f. Set CTRL2[LDMODE] to 1.
  - g. Set CTRL[DMAEN] to 1 to enable DMA function.
  - h. Set CTRL[LDOKE] to 1. This step is to ensure the DMA automatic operation occurs properly. DMA is triggered by loading values from outer-set to inner-set.
2. After initialization, the DMA is triggered in the following manner:
  - a. Values are loaded into inner-set registers when the counter rolls over or rolls under, then CTRL[LDOKE] is cleared automatically and a DMA request is sent out for next outer-set registers value update.

- b. After DMA updates the outer-set registers, CTRL[LDOOK] is set to 1 automatically. It then goes back to step a for iteration.

### 32.3.7 Modes of operation

eQDC operates in the following modes:

- Quadrature Decode Operation mode (CTRL[PH1] = 0, CTRL2[OPMODE] = 0)
- Quadrature Count Operation mode (CTRL[PH1] = 0, CTRL2[OPMODE] = 1)
- Single Phase Decode Operation mode (CTRL[PH1] = 1, CTRL2[OPMODE] = 0)
- Single Phase Count Operation mode (CTRL[PH1] = 1, CTRL2[OPMODE] = 1)

These operation modes support the following applications:

- Pulse accumulator
- Frequency Meter
- Period Meter
- PulseTrain Output with optional Quadrature and Direction

#### 32.3.7.1 Quadrature decode (QDC) operation mode (CTRL[PH1] = 0, CTRL2[OPMODE] = 0)

In this mode, PHASEA and PHASEB input signals from speed or position sensors are decoded by the following signals in eQDC:

1. PHASEA/PHASEB: Two 90 degree out of phase pulse trains.
2. INDEX: Can be configured to cause a change of state on REV, initialize POS, and reset POSD.
3. HOME: Can be configured to initialize POS.
4. TRIGGER: Can be configured to take a snapshot of POS, POSD, and REV and to reinitialize POS.
5. ICAP[3:1]: Takes a snapshot of POS.

eQDC outputs the following signals for system use:

- POS\_MATCH[3:0]: Position match:

Records the time at which the position of the shaft matches a user-defined value of the compare register or the time at which the position information is read:

- If CTRL2[OUTCTL] is cleared, POS\_MATCH[x](x range is 0-3) is asserted when the value of POS equals the value of the corresponding compare register (UCOMPx/LCOMPx), and de-asserted when the value of POS does not equal the value of the corresponding compare register (UCOMPx/LCOMPx).
- If CTRL2[OUTCTL] is set, POS\_MATCH[x](x range is 0-3) is asserted a pulse with 1 peripheral clock cycle width when UPOS or LPOS, REV, or POSD is read.

- COMP\_FLG[3:0]: Position Counter Compare Output:

- COMP\_FLG[x](x range is 0-3) is asserted when the value of Position Counter is equal to or greater than the value of the corresponding compare register (UCOMPx/LCOMPx).
- COMP\_FLG[x](x range is 0-3) is de-asserted when the value of Position Counter is smaller than the value of the corresponding compare register (UCOMPx/LCOMPx).

- DIR: Direction of position counting:

- Direction is up when DIR is asserted
- Direction is down when DIR is de-asserted.

- CNT\_UP: Position counter count up: when eQDC decodes a count-up event, CNT\_UP outputs a pulse which width is 1 peripheral clock cycle.

- CNT\_DN: Position counter count down: when eQDC decodes a count-down event, CNT\_DN outputs a pulse which width is 1 peripheral clock cycle.

There are three count modes(if CTRL[REV]=0,it is normal operation; if CTRL[REV]=1,it is reverse operation):

- Mode 0[CM0](CTRL2[CMODE]=00): Normal Quadrature X4 / Reverse Quadrature X4
- Mode 1[CM1](CTRL2[CMODE]=01): Normal Quadrature X2 / Reverse Quadrature X2
- Mode 2[CM2](CTRL2[CMODE]=10): Normal Quadrature X1 / Reverse Quadrature X1

### 32.3.7.2 Quadrature count (QCT) operation mode (CTRL[PH1] = 0, CTRL2[OPMODE] = 1)

In this mode, PHASEA and PHASEB input signals from speed or position sensors are counted by the following signals in eQDC:

- PHASEA/PHASEB: Two 90 degree out of phase pulse trains.
- PRESET: Initializes POS and resets POSD:
  - If CTRL[REV]=0, a positive edge of PRESET initializes POS to INIT value (UNIT/LINIT).
  - If CTRL[REV]=1, a positive edge of PRESET initializes POS to modulus value (UMOD/LMOD).
- ENABLE: All counters start counting when ENABLE is asserted; all counters stop counting when ENABLE is de-asserted.
- TRIGGER: Can be configured to take a snapshot of POS, POSD, and REV and to reinitialize POS.
- ICAP[3:1]: Takes a snapshot of POS.

eQDC outputs the following signals for system use:

- POS\_MATCH[3:0]: position match:

Records the time at which the position of the shaft matches a user-defined value of the compare register or the time at which the position information is read:

- If CTRL2[OUTCTL] is cleared, POS\_MATCH[x](x range is 0-3) is asserted when the value of POS equals the value of the corresponding compare register (UCOMPx/LCOMPx), and de-asserted when the value of POS does not equal the value of the corresponding compare register (UCOMPx/LCOMPx).
- If CTRL2[OUTCTL] is set, POS\_MATCH[x](x range is 0-3) is asserted a pulse with 1 peripheral clock cycle width when UPOS or LPOS, REV, or POSD is read.

- COMP\_FLG[3:0]: Position Counter Compare Output:

- COMP\_FLG[x](x range is 0-3) is asserted when the value of POS is equal to or greater than the value of the corresponding compare register (UCOMPx/LCOMPx).
- COMP\_FLG[x](x range is 0-3) is de-asserted when the value of POS is smaller than the value of the corresponding compare register (UCOMPx/LCOMPx).

- DIR: Direction of position counting:

- Direction is up when DIR is asserted
- Direction is down when DIR is de-asserted.

- CNT\_UP: Position counter count up: when eQDC decodes a count-up event, CNT\_UP outputs a pulse which width is 1 peripheral clock cycle.

- CNT\_DN: Position counter count down: when eQDC decodes a count-down event, CNT\_DN outputs a pulse which width is 1 peripheral clock cycle.

There are three count modes(if CTRL[REV]=0,it is normal operation; if CTRL[REV]=1,it is reverse operation):

- Mode 0[CM0](CTRL2[CMODE]=00): Normal Quadrature X4 / Reverse Quadrature X4
- Mode 1[CM1](CTRL2[CMODE]=01): Normal Quadrature X2 / Reverse Quadrature X2
- Mode 2[CM2](CTRL2[CMODE]=10): Normal Quadrature X1 / Reverse Quadrature X1

### 32.3.7.3 Single phase decode (PH1DC) operation mode (CTRL[PH1] = 1, CTRL2[OPMODE] = 0)

In this mode, PHASEA and PAHSEB input signals from speed or position sensors are decoded by the following signals in eQDC:

- PHASEA: Pulse trains.
- PHASEB: Pulse trains or direction.
- INDEX: Can be configured to cause a change of state on REV and to initialize POS.
- HOME: Can be configured to initialize POS.
- TRIGGER: Can be configured to take a snapshot of POS, POSD, and REV and to reinitialize POS.
- ICAP[3:1]: Takes a snapshot of POS.

eQDC outputs the following signals for system use:

- POS\_MATCH[3:0]: position match:

Records the time at which the position of the shaft matches a user-defined value of the compare register or the time at which the position information is read:

- If CTRL2[OUTCTL] is cleared, POS\_MATCH[x](x range is 0-3) is asserted when the value of POS equals the value of the corresponding compare register (UCOMPx/LCOMPx), and de-asserted when the value of POS does not equal the value of the corresponding compare register (UCOMPx/LCOMPx).
- If CTRL2[OUTCTL] is set, POS\_MATCH[x](x range is 0-3) is asserted a pulse with 1 peripheral clock cycle width when UPOS or LPOS, REV, or POSD is read.

- COMP\_FLG[3:0]: Position Counter Compare Output:

- COMP\_FLG[x](x range is 0-3) is asserted when the value of POS is equal to or greater than the value of the corresponding compare register (UCOMPx/LCOMPx).
- COMP\_FLG[x](x range is 0-3) is de-asserted when the value of POS is smaller than the value of the corresponding compare register (UCOMPx/LCOMPx).

- DIR: Direction of position counting:

- Direction is up when DIR is asserted
- Direction is down when DIR is de-asserted.

- CNT\_UP: Position counter count up: when eQDC decodes a count-up event, CNT\_UP outputs a pulse which width is 1 peripheral clock cycle.

- CNT\_DN: Position counter count down: when eQDC decodes a count-down event, CNT\_DN outputs a pulse which width is 1 peripheral clock cycle.

There are three count modes:

- Mode 0[CM0](CTRL2[CMODE]=00): **UP/DOWN Pulse Count mode**. Both position counter (POS) and position difference counter (POSD) count in the up direction when input PHASEA rising edge occurs. Both counters count in the down direction when input PHASEB rising edge occurs. If CTRL[REV] is 1, then the position counter will count in the opposite direction.
- Mode 1[CM1](CTRL2[CMODE]=01): **Signed Count mode (Double Edge)**. Both position counter (POS) and position difference counter (POSD) count the input PHASEA on both rising edge and falling edge while the input PHASEB provides the selected position counter direction (up/down). If CTRL[REV] is 1, then the position counter will count in the opposite direction.
- Mode 2[CM2](CTRL2[CMODE]=10): **Signed Count mode (Single Edge)**. Both position counter (POS) and position difference counter (POSD) count on the input PHASEA rising edge while the input PHASEB provides the selected position counter direction (up/down). If CTRL[REV] is 1, then the position counter will count in the opposite direction.

**NOTE**

If the positive edge of both PHASEA and PHASEB occurs simultaneously, an error interrupt is generated  
CTRL2[SABIRQ] and counter is unchanged.

### 32.3.7.4 Single phase count (PH1CT) operation mode (CTRL[PH1] =1, CTRL2[OPMODE] = 1)

In this mode, PHASEA and PHASEB input signals from speed or position sensors are counted by the following signals in eQDC:

- PHASEA: Pulse trains.
- PHASEB: Pulse trains or direction.
- PRESET: Initializes POS and resets POSD:
  - If CTRL[REV]=0, a positive edge of PRESET initializes POS to initial value (UNIT/LINIT).
  - If CTRL[REV]=1, a positive edge of PRESET initializes POS to modulus value (UMOD/LMOD).
- ENABLE: All counters start counting when ENABLE is asserted; all counters stop counting when ENABLE is de-asserted.
- TRIGGER: Can be configured to take a snapshot of POS, POSD, and REV, and to reinitialize POS.
- ICAP[3:1]: Takes a snapshot of POS.

eQDC outputs the following signals for system use:

- POS\_MATCH[3:0]: position match:

Records the time at which the position of the shaft matches a user-defined value of the compare register or the time at which the position information is read:

- If CTRL2[OUTCTL] is cleared, POS\_MATCH[x](x range is 0-3) is asserted when the value of POS equals the value of the corresponding compare register (UCOMPx/LCOMPx), and de-asserted when the value of POS does not equal the value of the corresponding compare register (UCOMPx/LCOMPx).
- If CTRL2[OUTCTL] is set, POS\_MATCH[x](x range is 0-3) is asserted a pulse with 1 peripheral clock cycle width when UPOS or LPOS, REV, or POSD is read.

- COMP\_FLG[3:0]: Position Counter Compare Output:

- COMP\_FLG[x](x range is 0-3) is asserted when the value of POS is equal to or greater than the value of the corresponding compare register (UCOMPx/LCOMPx).
- COMP\_FLG[x](x range is 0-3) is de-asserted when the value of POS is smaller than the value of the corresponding compare register (UCOMPx/LCOMPx).

- DIR: Direction of position counting:

- Direction is up when DIR is asserted
- Direction is down when DIR is de-asserted.

- CNT\_UP: Position counter count up: when eQDC decodes a count-up event, CNT\_UP outputs a pulse which width is 1 peripheral clock cycle.

- CNT\_DN: Position counter count down: when eQDC decodes a count-down event, CNT\_DN outputs a pulse which width is 1 peripheral clock cycle.

There are three count modes:

- Mode 0[CM0](CTRL2[CMODE]=00): **UP/DOWN Pulse Count mode**. Both position counter (POS) and position difference counter (POSD) count in the up direction when input PHASEA rising edge occurs, both counters count in the down direction when input PHASEB rising edge occurs.
- Mode 1[CM1](CTRL2[CMODE]=01): **Signed Count mode (Double Edge)**. Both position counter (POS) and position difference counter (POSD) count the input PHASEA on both rising edge and falling edge while the input PHASEB provides the selected position counter direction (up/down) .

- Mode 2[CM2](CTRL2[CMODE]=10): **Signed Count mode (Single Edge)**. Both position counter (POS) and position difference counter (POSD) count on the input PHASEA rising edge while the input PHASEB provides the selected position counter direction (up/down).

**NOTE**

If the positive edge of both PHASEA and PHASEB occurs simultaneously, an error interrupt is generated  
CTRL2[SABIRQ] and counter is unchanged.

**32.3.7.5 Normal quadrature X1**

Figure 130. Normal quadrature X1

**32.3.7.6 Normal quadrature X2**

Figure 131. Normal quadrature X2

**32.3.7.7 Normal quadrature X4**

Figure 132. Normal quadrature X4

### 32.3.7.8 Reverse quadrature X1



Figure 133. Reverse quadrature X1

**NOTE**

Set CTRL[REV] to 1 for the position counter to count in the opposite direction.

### 32.3.7.9 Reverse quadrature X2



Figure 134. Reverse quadrature X2

**NOTE**

Set CTRL[REV] to 1 for the position counter to count in the opposite direction.

### 32.3.7.10 Reverse quadrature X4



Figure 135. Reverse quadrature X4

**NOTE**

Set CTRL[REV] to 1 for the position counter to count in the opposite direction.

### 32.3.7.11 UP/DOWN pulse count mode



Figure 136. UP/DOWN pulse count mode

### 32.3.7.12 Signed count mode (double edge)



Figure 137. Signed count mode (double edge)

### 32.3.7.13 Signed count mode (single edge)



Figure 138. Signed count mode (single edge)

## 32.3.8 Speed measurement method

This section explains the speed measurement method, including the speed measurement algorithm.

The following figure shows the module working mechanism.



The following figure shows counters behavior and updating mechanism in the speed measurement method.



Figure 140. Counters behavior and updating mechanism

A reading of POSD occurs at time point A and it also occurs at time point B. "Actual time" represents the time duration between the first phase\_a/b edges right before time points A and B. At time point B, after reading POSD, POSDPERH contains the time length of "Actual time" and POSDH contains the value of phase\_a/b pulses within that "Actual time". Speed can be calculated based on POSDPERH and POSDH. A visualized explanation of speed measurement with this method is shown in the figure below.



Figure 141. High speed measurement with method

### Speed calculation algorithm

In order to cover all the cases in real applications, a simple speed measurement algorithm is necessary. See the algorithm shown below.



Figure 142. Flowchart of speed calculation with method

## Speed calculation of motor's starting from standstill (chip is out of reset)



Figure 143. Speed measurement at time point T1~T3



Figure 144. Speed measurement at time point T4



## Speed calculation when motor stops



Figure 147. Speed measurement at time point T8



Figure 148. Speed measurement at time point Tn

## Speed calculation when motor starts again

Figure 149. Speed measurement at time point  $T_{n+2}$





### 32.3.9 Reset

eQDC is reset by any system reset. Make sure you clear all inputs (of PhaseA, PhaseB, and etc.) before resetting eQDC.

### 32.3.10 Clocking

The peripheral clock is the only clock required when eQDC operates.

### 32.3.11 Interrupts

The following table lists the module interrupts.

**Table 175. Interrupt Summary**

| Core Interrupt | Interrupt Flag | Interrupt Enable | Description                              |
|----------------|----------------|------------------|------------------------------------------|
| ipi_int_home   | CTRL[HIRQ]     | CTRL[HIE]        | HOME/ENABLE signal transition interrupt  |
| ipi_int_index  | CTRL[XIRQ]     | CTRL[XIE]        | INDEX/PRESET signal transition interrupt |
| ipi_int_ro     | INTCTRL[ROIRQ] | INTCTRL[ROIE]    | roll-over interrupt                      |
| ipi_int_ru     | INTCTRL[RUIRQ] | INTCTRL[RUIE]    | roll-under interrupt                     |

*Table continues on the next page...*

Table 175. Interrupt Summary (continued)

| Core Interrupt | Interrupt Flag                         | Interrupt Enable                     | Description                                     |
|----------------|----------------------------------------|--------------------------------------|-------------------------------------------------|
| ipi_int_wdog   | CTRL[WDIRQ]                            | CTRL[WDIE]                           | Watchdog timeout interrupt                      |
| ipi_int_comp   | INTCTRL[CMP0IRQ]<br>~ INTCTRL[CMP3IRQ] | INTCTRL[CMP0IE]<br>~ INTCTRL[CMP3IE] | Compare match interrupt                         |
| ipi_int_dir    | INTCTRL[DIRIRQ]                        | INTCTRL[DIRIE]                       | Count direction change interrupt                |
| ipi_int_sab    | INTCTRL[SABIRQ]                        | INTCTRL[SABIE]                       | Simultaneous PHASEA and PHASEB change interrupt |

### 32.4 External signals

eQDC receives the following 8 input signals from position or speed sensors:

- PHASEA
- PHASEB
- INDEX/PRESET
- TRIGGER
- HOME/ENABLE
- ICAP[3:1]

eQDC outputs the following 11 signals for system use:

- POS\_MATCH[3:0]
- COMP\_FLG[3:0]
- DIR
- CNT\_DN
- CNT\_UP

Table 176. Signals

| Signal |         |       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|---------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PHASEA | Phase A | Input | <p>The PHASEA input can be connected to one of the phases from a two-phase shaft quadrature encoder output. PHASEA and PHASEB are used by eQDC to indicate a decoder increment has passed, and to calculate its direction.</p> <ul style="list-style-type: none"> <li>• When eQDC is used as a single phase decode/count, PHASEA can also be used as the single input.</li> </ul> <p>Direction for two-phase shaft quadrature encoder output when CTRL[REV] = 0:</p> <ul style="list-style-type: none"> <li>• PHASEA is the leading phase for a shaft rotating in the positive direction.</li> <li>• PHASEA is the trailing phase for a shaft rotating in the negative direction.</li> </ul> |

*Table continues on the next page...*

Table 176. Signals (continued)

| Signal           |                  |       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------|------------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PHASEB           | Phase B          | Input | <p>The PHASEB input can be connected to the other phase from a two-phase shaft quadrature encoder output.</p> <ul style="list-style-type: none"> <li>When eQDC is used as a single phase decode/count mode, PHASEB and CTRL[REV] control counter direction.</li> </ul> <p>Direction for two-phase shaft quadrature encoder output when CTRL[REV] = 0:</p> <ul style="list-style-type: none"> <li>PHASEB is the trailing phase for a shaft rotating in the positive direction.</li> <li>PHASEB is the leading phase for a shaft rotating in the negative direction.</li> </ul>                                                                                                                                               |
| INDEX/<br>PRESET | INDEX/<br>PRESET | Input | <ul style="list-style-type: none"> <li>This input can work as INDEX or PRESET, selection bit is CTRL2[OPMODE]</li> <li>Normally connected to the index pulse output of a quadrature encoder, the INDEX pulse can optionally reset the position counter of eQDC. The INDEX pulse also causes a change of state on the revolution counter. The direction of this state change (increment or decrement) is calculated from the PHASEA and PHASEB inputs.</li> </ul> <p>In Quadrature Count mode or Single Phase Count mode, this signal can present the counter PRESET function.</p> <ul style="list-style-type: none"> <li>The positive edge of PRESET input can initialize position/revolution/watchdog counters.</li> </ul> |
| HOME/ENABLE      | HOME/ENABLE      | Input | <p>The HOME input can be used by eQDC and the timer module.</p> <ul style="list-style-type: none"> <li>This input can work as HOME or ENABLE, selection bit is CTRL2[OPMODE]</li> <li>The HOME input can be used to trigger the initialization of the position counter (UPOS/LPOS). Often the HOME signal is connected to a sensor on the motor or machine, sending notification that it has reached a defined home position.</li> </ul> <p>In Quadrature Count mode or Single Phase Count mode, this signal can present the counter ENABLE function.</p> <ul style="list-style-type: none"> <li>All counters start counting when ENABLE is asserted, all counters stop counting when ENABLE is de-asserted.</li> </ul>     |
| TRIGGER          | TRIGGER          | Input | <ul style="list-style-type: none"> <li>Initializes UPOS or LPOS.</li> <li>Takes a snapshot of POS, REV, and POSD.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| ICAP[3:1]        | Input capture    | Input | <p>Takes snapshots of POS and stores them into the corresponding UPOSH/LPOSH:</p> <ul style="list-style-type: none"> <li>Positive edge of ICAP[3] input takes snapshots of POS and stores it into UPOSH3/LPOSH3.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

*Table continues on the next page...*

Table 176. Signals (continued)

| Signal         |                                 |        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|---------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                |                                 |        | <ul style="list-style-type: none"> <li>Positive edge of ICAP[2] input takes snapshots of POS and stores it into UPOSH2/LPOSH2.</li> <li>Positive edge of ICAP[1] input takes snapshots of POS and stores it into UPOSH1/LPOSH1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| POS_MATCH[3:0] | Position Match                  | Output | <ul style="list-style-type: none"> <li>Records the time at which the position of the shaft matches a user-defined compare value (UCOMPx/LCOMPx), the POS_MATCH[x](x range is 0-3) output can be used to trigger a timer channel.</li> <li>Alternatively, records the time at which the position information was read, (when the position counters (UPOS and LPOS), revolution counter (REV), or position difference counter (POSD) registers are read) the POS_MATCH[x](x range is 0-3) output can be used to trigger a timer channel.</li> </ul> <p>Note:</p> <ul style="list-style-type: none"> <li>If CTRL2[OUTCTL] is cleared, POS_MATCH[x](x range is 0-3) is asserted when the value of POS equals the value of the corresponding compare register (UCOMPx/LCOMPx), and de-asserted when the value of POS does not equal the value of the corresponding compare register (UCOMPx/LCOMPx).</li> <li>If CTRL2[OUTCTL] is set, POS_MATCH[x](x range is 0-3) is asserted a pulse with 1 peripheral clock cycle width when UPOS or LPOS, REV, or POSD is read.</li> </ul> |
| COMP_FLG[3:0]  | Position Counter Compare Output | Output | <ul style="list-style-type: none"> <li>COMP_FLG[x](x range is 0-3) is asserted when the value of POS is equal to or greater than the value of the corresponding compare register (UCOMPx/LCOMPx).</li> <li>COMP_FLG[x](x range is 0-3) is de-asserted when the value of POS is smaller than the value of the corresponding compare register (UCOMPx/LCOMPx).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| DIR            | Direction of position counting  | Output | Indicates the direction of position counting: <ul style="list-style-type: none"> <li>1 indicates up.</li> <li>0 indicates down.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| CNT_UP         | Position counter count up       | Output | When eQDC decodes a count-up event, CNT_UP outputs a pulse with a width of 1 peripheral clock cycle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| CNT_DN         | position counter count down     | Output | When eQDC decodes a count-down event, CNT_DN outputs a pulse with a width of 1 peripheral clock cycle.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

## 32.5 Initialization

This module does not require initialization.

## 32.6 Register descriptions

This section describes the memory map and registers of eQDC.

### 32.6.1 Quadrature\_Decoder register descriptions

The address of a register is the sum of a base address and an address offset.

#### 32.6.1.1 Quadrature\_Decoder memory map

QDC0 base address: 400A\_7000h

| Offset | Register                                                | Width<br>(In bits) | Access | Reset value |
|--------|---------------------------------------------------------|--------------------|--------|-------------|
| 0h     | Control Register (CTRL)                                 | 16                 | RW     | 0000h       |
| 2h     | Control 2 Register (CTRL2)                              | 16                 | RW     | 0000h       |
| 4h     | Input Filter Register (FILT)                            | 16                 | RW     | 0000h       |
| 6h     | Last Edge Time Register (LASTEDGE)                      | 16                 | R      | FFFFh       |
| 8h     | Position Difference Period Counter Register (POSDPER)   | 16                 | R      | FFFFh       |
| Ah     | Position Difference Period Buffer Register (POSDPERBFR) | 16                 | R      | FFFFh       |
| Ch     | Upper Position Counter Register (UPOS)                  | 16                 | RW     | 0000h       |
| Eh     | Lower Position Counter Register (LPOS)                  | 16                 | RW     | 0000h       |
| 10h    | Position Difference Counter Register (POSD)             | 16                 | RW     | 0000h       |
| 12h    | Position Difference Hold Register (POSDH)               | 16                 | R      | 0000h       |
| 14h    | Upper Position Hold Register (UPOSH)                    | 16                 | R      | 0000h       |
| 16h    | Lower Position Hold Register (LPOSH)                    | 16                 | R      | 0000h       |
| 18h    | Last Edge Time Hold Register (LASTEDGEH)                | 16                 | R      | FFFFh       |
| 1Ah    | Position Difference Period Hold Register (POSDPERH)     | 16                 | R      | FFFFh       |
| 1Ch    | Revolution Hold Register (REVH)                         | 16                 | R      | 0000h       |
| 1Eh    | Revolution Counter Register (REV)                       | 16                 | RW     | 0000h       |
| 20h    | Upper Initialization Register (UINIT)                   | 16                 | RW     | 0000h       |
| 22h    | Lower Initialization Register (LINIT)                   | 16                 | RW     | 0000h       |
| 24h    | Upper Modulus Register (UMOD)                           | 16                 | RW     | 0000h       |
| 26h    | Lower Modulus Register (LMOD)                           | 16                 | RW     | 0000h       |
| 28h    | Upper Position Compare Register 0 (UCOMP0)              | 16                 | RW     | 8000h       |
| 2Ah    | Lower Position Compare Register 0 (LCOMP0)              | 16                 | RW     | 0000h       |
| 2Ch    | Upper Position Compare 1 (UCOMP1)                       | 16                 | W      | 8000h       |
| 2Ch    | Upper Position Holder Register 1 (UPOSH1)               | 16                 | R      | 0000h       |
| 2Eh    | Lower Position Compare 1 (LCOMP1)                       | 16                 | W      | 0000h       |
| 2Eh    | Lower Position Holder Register 1 (LPOSH1)               | 16                 | R      | 0000h       |
| 30h    | Upper Position Compare 2 (UCOMP2)                       | 16                 | W      | 8000h       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset | Register                                  | Width<br>(In bits) | Access | Reset value |
|--------|-------------------------------------------|--------------------|--------|-------------|
| 30h    | Upper Position Holder Register 3 (UPOSH2) | 16                 | R      | 0000h       |
| 32h    | Lower Position Compare 2 (LCOMP2)         | 16                 | W      | 0000h       |
| 32h    | Lower Position Holder Register 2 (LPOSH2) | 16                 | R      | 0000h       |
| 34h    | Upper Position Compare 3 (UCOMP3)         | 16                 | W      | 8000h       |
| 34h    | Upper Position Holder Register 3 (UPOSH3) | 16                 | R      | 0000h       |
| 36h    | Lower Position Compare 3 (LCOMP3)         | 16                 | W      | 0000h       |
| 36h    | Lower Position Holder Register 3 (LPOSH3) | 16                 | R      | 0000h       |
| 38h    | Interrupt Control Register (INTCTRL)      | 16                 | RW     | 0000h       |
| 3Ah    | Watchdog Timeout Register (WTR)           | 16                 | RW     | 0000h       |
| 3Ch    | Input Monitor Register (IMR)              | 16                 | RW     | 0000h       |
| 3Eh    | Test Register (TST)                       | 16                 | RW     | 0000h       |
| 50h    | Upper VERID (UVERID)                      | 16                 | R      | 0001h       |
| 52h    | Lower VERID (LVERID)                      | 16                 | R      | 0001h       |

### 32.6.1.2 Control Register (CTRL)

#### Offset

| Register | Offset |
|----------|--------|
| CTRL     | 0h     |

#### Function

Controls various features of eQDC.

**Diagram**

| Bits  | 15   | 14  | 13  | 12  | 11   | 10  | 9   | 8    | 7   | 6   | 5   | 4      | 3    | 2   | 1      | 0    |
|-------|------|-----|-----|-----|------|-----|-----|------|-----|-----|-----|--------|------|-----|--------|------|
| R     | HIRQ | HIE | HIP | HNE | 0    | REV | PH1 | XIRQ | XIE | XIP | XNE | WDIR Q | WDIE | WDE | DMAE N | LDOK |
| W     | W1C  |     |     |     | SWIP |     |     | W1C  |     |     |     | W1C    |      |     |        |      |
| Reset | 0    | 0   | 0   | 0   | 0    | 0   | 0   | 0    | 0   | 0   | 0   | 0      | 0    | 0   | 0      | 0    |

**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>HIRQ | <p>HOME/ENABLE Signal Transition Interrupt Request</p> <p>HOME/ENABLE Signal Transition Interrupt Request is set when a positive or negative transition on the HOME/ENABLE signal occurs, according to the Use Negative Edge of HOME/ENABLE Input bit (CTRL[HNE]). If HOME/ENABLE Signal Transition Interrupt Request bit is set and HOME/ENABLE Interrupt Enable bit (CTRL[HIE]) is set, then a HOME/ENABLE interrupt occurs.</p> <ul style="list-style-type: none"> <li>• HOME/ENABLE Signal Transition Interrupt Request bit remains set until it is cleared by software</li> <li>• Write a one to this bit (HIRQ) to clear it</li> </ul> <p>0b - No transition on the HOME/ENABLE signal has occurred<br/>1b - A transition on the HOME/ENABLE signal has occurred</p> |
| 14<br>HIE  | <p>HOME/ENABLE Interrupt Enable</p> <p>Enables/disables HOME/ENABLE signal interrupts.</p> <p>0b - Disabled<br/>1b - Enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 13<br>HIP  | <p>Enable HOME to Initialize Position Counter UPOS/LPOS</p> <p>Enables the position counter to be initialized by the HOME signal.</p> <p>0b - No action<br/>1b - HOME signal initializes the position counter</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 12<br>HNE  | <p>Use Negative Edge of HOME/ENABLE Input</p> <p>Selects using the positive/negative edge of the HOME/ENABLE input.</p> <p>0b - When CTRL[OPMODE] = 0,use HOME positive edge to trigger initialization of position counters. When CTRL[OPMODE] = 1,use ENABLE high level to enable POS/POSD/WDG/REV counters</p> <p>1b - When CTRL[OPMODE] = 0,use HOME negative edge to trigger initialization of position counters. When CTRL[OPMODE] = 1,use ENABLE low level to enable POS/POSD/WDG/REV counters</p>                                                                                                                                                                                                                                                                   |
| 11<br>SWIP | <p>Software-Triggered Initialization of Position Counters UPOS and LPOS</p> <p>Writing 1 to Software-Triggered Initialization of Position Counters bit initializes the position counter.</p> <ul style="list-style-type: none"> <li>• Software-Triggered Initialization of Position Counters bit is always read as 0.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                           |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | 0b - No action<br>1b - Initialize position counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 10<br>REV | Enable Reverse Direction Counting<br>Selects the direction of the count and position counter initial value.<br>Note: if CTRL2[EMIP]=1 and INDEX input transition initialize position counter, this REV bit affects position counter initial value in a different manner, please refer to chapter "Position Counter(POS)" in Functional Description. Otherwise, REV bit takes affect as following:<br>0b - Count normally and the position counter initialization uses upper/lower initialization register UINIT/LINIT<br>1b - Count in the reverse direction and the position counter initialization uses upper/lower modulus register UMOD/LMOD   |
| 9<br>PH1  | Enable Single Phase Mode<br>Bypass/use the quadrature decoder logic.<br>0b - Standard quadrature decoder, where PHASEA and PHASEB represent a two-phase quadrature signal.<br>1b - Single phase mode, bypass the quadrature decoder, refer to CTRL2[CMODE] description                                                                                                                                                                                                                                                                                                                                                                             |
| 8<br>XIRQ | INDEX/PRESET Pulse Interrupt Request<br>INDEX/PRESET Pulse Interrupt Request is set when a transition on the INDEX/PRESET signal occurs, according to the Use Negative Edge of INDEX/PRESET Pulse bit (CTRL[XNE]). If INDEX/PRESET Pulse Interrupt Request bit is set and INDEX/PRESET Pulse Interrupt Enable bit (CTRL[XIE]) is set, then an INDEX/PRESET interrupt occurs. <ul style="list-style-type: none"> <li>• INDEX/PRESET Pulse Interrupt Request remains set until cleared by software</li> <li>• Write a one to this bit (XIRQ) to clear it</li> </ul> 0b - INDEX/PRESET pulse has not occurred<br>1b - INDEX/PRESET pulse has occurred |
| 7<br>XIE  | INDEX/PRESET Pulse Interrupt Enable<br>Enables/disables INDEX/PRESET pulse interrupts. <ul style="list-style-type: none"> <li>0b - Disabled</li> <li>1b - Enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 6<br>XIP  | INDEX Triggered Initialization of Position Counters UPOS and LPOS<br>Enables/disables the position counter to be initialized by the INDEX pulse. <ul style="list-style-type: none"> <li>0b - INDEX pulse does not initialize the position counter</li> <li>1b - INDEX pulse initializes the position counter</li> </ul>                                                                                                                                                                                                                                                                                                                            |
| 5         | Select Positive/Negative Edge of INDEX/PRESET Pulse                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                           |               |               |                           |                          |                           |                                  |                           |                          |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|---------------|---------------|---------------------------|--------------------------|---------------------------|----------------------------------|---------------------------|--------------------------|
| XNE                              | <p>Selects the positive/negative edge of the INDEX/PRESET pulse.</p> <p>Note: if CTRL2[EMIP]=1 and CTRL2[OPMODE]=0, XNE bit affects INDEX pulse in a different manner as following table:</p> <table border="1"> <thead> <tr> <th></th><th>CTRL[XNE] = 0</th><th>CTRL[XNE] = 1</th></tr> </thead> <tbody> <tr> <td>PHA leads PHB (Clockwise)</td><td>Use rising edge of Index</td><td>Use falling edge of Index</td></tr> <tr> <td>PHA lags PHB (Counter Clockwise)</td><td>Use falling edge of Index</td><td>Use rising edge of Index</td></tr> </tbody> </table> <p>otherwise, XNE bit affects INDEX pulse as following:</p> <ul style="list-style-type: none"> <li>0b - Use positive edge of INDEX/PRESET pulse</li> <li>1b - Use negative edge of INDEX/PRESET pulse</li> </ul> |                           | CTRL[XNE] = 0 | CTRL[XNE] = 1 | PHA leads PHB (Clockwise) | Use rising edge of Index | Use falling edge of Index | PHA lags PHB (Counter Clockwise) | Use falling edge of Index | Use rising edge of Index |
|                                  | CTRL[XNE] = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | CTRL[XNE] = 1             |               |               |                           |                          |                           |                                  |                           |                          |
| PHA leads PHB (Clockwise)        | Use rising edge of Index                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Use falling edge of Index |               |               |                           |                          |                           |                                  |                           |                          |
| PHA lags PHB (Counter Clockwise) | Use falling edge of Index                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Use rising edge of Index  |               |               |                           |                          |                           |                                  |                           |                          |
| 4<br>WDIRQ                       | <p>Watchdog Timeout Interrupt Request</p> <p>Watchdog Timeout Interrupt Request is set when a watchdog timeout interrupt occurs.</p> <ul style="list-style-type: none"> <li>• Watchdog Timeout Interrupt Request remains set until cleared by software</li> <li>• Write a one to this bit (WDIRQ) to clear it</li> <li>• Watchdog Timeout Interrupt Request bit is also cleared when Watchdog Enable (CTRL[WDE]) is disabled (=0)</li> </ul> <ul style="list-style-type: none"> <li>0b - No Watchdog timeout interrupt has occurred</li> <li>1b - Watchdog timeout interrupt has occurred</li> </ul>                                                                                                                                                                                |                           |               |               |                           |                          |                           |                                  |                           |                          |
| 3<br>WDIE                        | <p>Watchdog Timeout Interrupt Enable</p> <p>Enables/disables watchdog timeout interrupts.</p> <ul style="list-style-type: none"> <li>0b - Disabled</li> <li>1b - Enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                           |               |               |                           |                          |                           |                                  |                           |                          |
| 2<br>WDE                         | <p>Watchdog Enable</p> <p>Enables/disables the watchdog timer that is monitoring the PHASEA and PHASEB inputs for motor movement.</p> <ul style="list-style-type: none"> <li>0b - Disabled</li> <li>1b - Enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                           |               |               |                           |                          |                           |                                  |                           |                          |
| 1<br>DMAEN                       | <p>DMA Enable</p> <p>This bit enables DMA for new written buffer values of COMPx/INIT/MOD(x range is 0-3)</p> <p>Please note: When set to 1, this bit can't be cleared by writing 0 to it.</p> <ul style="list-style-type: none"> <li>0b - DMA is disabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                           |               |               |                           |                          |                           |                                  |                           |                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | <p>1b - DMA is enabled. DMA request asserts automatically when the values in the outer-set of buffered compare registers (UCOMP0/LCOMP0;UCOMP1/LCOMP1;UCOMP2/LCOMP2;UCOMP3/LCOMP3), initial registers(UINIT/LINIT) and modulus registers (UMOD/LMOD) are loaded into the inner-set of buffer and then LDOK is cleared automatically. After the completion of this DMA transfer, LDOK is set automatically, it ensures outer-set values can be loaded into inner-set which in turn triggers DMA again.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0<br>LDOK | <p>Load Okay</p> <p>This bit enables that the outer-set values of buffered compare registers (UCOMPx/LCOMPx, x=0~3), initial register(UINIT/LINIT) and modulus register(UMOD/LMOD) can be loaded into their inner-sets and take effect.</p> <p>When LDOK is set, this loading action occurs at the next position counter roll-over or roll-under if CTRL2[LDMOD] is set, or it occurs immediately if CTRL2[LDMOD] is cleared. LDOK is automatically cleared after the values in outer-set is loaded into the inner-set.</p> <p>Set LDOK bit by reading it, then write a logic 1 to it. LDOK can be manually cleared before a loading action occurs by writing a logic 0 to it. The outer-set of the registers cannot be written while LDOK is 1.</p> <p>0b - No loading action taken. Users can write new values to buffered registers (writing into outer-set of these buffered registers)</p> <p>1b - Outer-set values are ready to be loaded into inner-set and take effect. The loading time point depends on CTRL2[LDMOD].</p> |

### 32.6.1.3 Control 2 Register (CTRL2)

#### Offset

| Register | Offset |
|----------|--------|
| CTRL2    | 2h     |

#### Function

Controls various features of eQDC.

**Diagram**

| Bits | 15    | 14   | 13      | 12 | 11   | 10   | 9       | 8     | 7 | 6 | 5 | 4 | 3     | 2      | 1       | 0      |
|------|-------|------|---------|----|------|------|---------|-------|---|---|---|---|-------|--------|---------|--------|
| R    | CMODE | ONCE | INITPOS |    | EMIP | PMEN | OUTC TL | REVMD | 0 |   |   |   | LDMOD | OPMODO | UPDPDOS | UPDHLD |
| W    | 0     | 0    | 0       | 0  | 0    | 0    | 0       | 0     | 0 | 0 | 0 | 0 | 0     | 0      | 0       | 0      |

**Fields**

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-14<br>CMODE | <p>Counting Mode</p> <p>These bits control the basic counting and behavior of Position Counter and Position Difference Counter. Setting CTRL[REV] to 1 can reverse the counting direction.</p> <p>In quadrature Mode (CTRL[PH1] = 0):</p> <ul style="list-style-type: none"> <li>00b - CM0: Normal/Reverse Quadrature X4</li> <li>01b - CM1: Normal/Reverse Quadrature X2</li> <li>10b - CM2: Normal/Reverse Quadrature X1</li> <li>11b - CM3: Reserved</li> </ul> <p>In Single Phase Mode (CTRL[PH1] = 1):</p> <ul style="list-style-type: none"> <li>00b - CM0: UP/DOWN Pulse Count Mode</li> <li>01b - CM1: Signed Mode, count PHASEA rising/falling edge, position counter counts up when PHASEB is low and counts down when PHASEB is high</li> <li>10b - CM2: Signed Count Mode, count PHASEA rising edge only, position counter counts up when PHASEB is low and counts down when PHASEB is high</li> <li>11b - CM3: Reserved</li> </ul> |
| 13<br>ONCE     | <p>Count Once</p> <p>This bit selects modulo loop or one shot counting mode.</p> <p><b>NOTE</b></p> <p>Any of the following event initializes and restarts the position counter:</p> <ul style="list-style-type: none"> <li>• Write to CTRL[SWIP].</li> <li>• INDEX signal transition if CTRL2[OPMODE] bit is clear and CTRL[XIP] is set.</li> <li>• HOME signal transition if CTRL2[OPMODE] bit is clear and CTRL[HIP] is set.</li> <li>• PRESET signal transition if CTRL2[OPMODE] bit is set and ENABLE signal is 1.</li> <li>• Positive edge transition of TRIGGER input if CTRL2[INITPOS] is set.</li> </ul> <p>0b - Position counter counts repeatedly</p> <p>1b - Position counter counts until roll-over or roll-under, then stop.</p>                                                                                                                                                                                                  |
| 12<br>INITPOS  | Initial Position Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                           |                                         |                                         |               |               |                           |                                          |                                           |                                         |                                         |                                  |                                           |                                          |                                         |                                         |
|----------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|-----------------------------------------|-----------------------------------------|---------------|---------------|---------------------------|------------------------------------------|-------------------------------------------|-----------------------------------------|-----------------------------------------|----------------------------------|-------------------------------------------|------------------------------------------|-----------------------------------------|-----------------------------------------|
|                                  | <ul style="list-style-type: none"> <li>When Initial Position Register is set (=1), it allows the rising edge of TRIGGER input to initialize the position counter (UPOS and LPOS registers) to UINIT/LINIT values (if CTRL[REV]=0) or UMOD/LMOD values (if CTRL[REV]=1).</li> <li>When Initial Position Register is clear (=0), the position counter (UPOS/LPOS) is not initialized on rising edge of TRIGGER input           <ul style="list-style-type: none"> <li>0b - Don't initialize position counter on rising edge of TRIGGER</li> <li>1b - Initialize position counter on rising edge of TRIGGER</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                           |                                         |                                         |               |               |                           |                                          |                                           |                                         |                                         |                                  |                                           |                                          |                                         |                                         |
| 11<br>EMIP                       | <p>Enables/disables the position counter to be initialized by Index Event Edge Mark</p> <p>When CTRL[XIP] =1, this bit is used to enable the position counter to be initialized by Index Event Edge Mark cooperated with CTRL[REV] and CTRL[XNE] as following table:</p> <table border="1"> <thead> <tr> <th></th> <th>CTRL[XNE] = 0</th> <th>CTRL[XNE] = 1</th> <th>CTRL[REV] = 0</th> <th>CTRL[REV] = 1</th> </tr> </thead> <tbody> <tr> <td>PHA leads PHB (Clockwise)</td> <td>INDEX rising edge reset position counter</td> <td>INDEX falling edge reset position counter</td> <td>Reset position counter to initial value</td> <td>Reset position counter to modulus value</td> </tr> <tr> <td>PHA lags PHB (Counter Clockwise)</td> <td>INDEX falling edge reset position counter</td> <td>INDEX rising edge reset position counter</td> <td>Reset position counter to modulus value</td> <td>Reset position counter to initial value</td> </tr> </tbody> </table> <p>0b - disables the position counter to be initialized by Index Event Edge Mark</p> <p>1b - enables the position counter to be initialized by Index Event Edge Mark.</p> |                                           | CTRL[XNE] = 0                           | CTRL[XNE] = 1                           | CTRL[REV] = 0 | CTRL[REV] = 1 | PHA leads PHB (Clockwise) | INDEX rising edge reset position counter | INDEX falling edge reset position counter | Reset position counter to initial value | Reset position counter to modulus value | PHA lags PHB (Counter Clockwise) | INDEX falling edge reset position counter | INDEX rising edge reset position counter | Reset position counter to modulus value | Reset position counter to initial value |
|                                  | CTRL[XNE] = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | CTRL[XNE] = 1                             | CTRL[REV] = 0                           | CTRL[REV] = 1                           |               |               |                           |                                          |                                           |                                         |                                         |                                  |                                           |                                          |                                         |                                         |
| PHA leads PHB (Clockwise)        | INDEX rising edge reset position counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | INDEX falling edge reset position counter | Reset position counter to initial value | Reset position counter to modulus value |               |               |                           |                                          |                                           |                                         |                                         |                                  |                                           |                                          |                                         |                                         |
| PHA lags PHB (Counter Clockwise) | INDEX falling edge reset position counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | INDEX rising edge reset position counter  | Reset position counter to modulus value | Reset position counter to initial value |               |               |                           |                                          |                                           |                                         |                                         |                                  |                                           |                                          |                                         |                                         |
| 10<br>PMEN                       | <p>Period measurement function enable</p> <p>This bit is used to indicate the period measurement functions of LASTEDGE, LASTEDGEH, POSDPER, POSDPERBFR, and POSDPERH are being used.</p> <p>0b - Period measurement functions are not used. POSD is loaded to POSDH and then cleared whenever POSD, UPOS, LPOS or REV is read.</p> <p>1b - Period measurement functions are used. POSD is loaded into POSDH and then cleared only when POSD is read.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                           |                                         |                                         |               |               |                           |                                          |                                           |                                         |                                         |                                  |                                           |                                          |                                         |                                         |
| 9<br>OUTCTL                      | <p>Output Control</p> <p>Output Control controls the pulsing of the POS_MATCH output signal.</p> <p>0b - POS_MATCH[x](x range is 0-3) is asserted when the Position Counter is equal to according compare value (UCOMPx/LCOMPx)(x range is 0-3), and de-asserted when the Position Counter not equal to the compare value (UCOMPx/LCOMPx)(x range is 0-3)</p> <p>1b - All POS_MATCH[x](x range is 0-3) are asserted a pulse, when the UPOS, LPOS, REV, or POSD registers are read</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                           |                                         |                                         |               |               |                           |                                          |                                           |                                         |                                         |                                  |                                           |                                          |                                         |                                         |
| 8<br>REVMOD                      | Revolution Counter Modulus Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                           |                                         |                                         |               |               |                           |                                          |                                           |                                         |                                         |                                  |                                           |                                          |                                         |                                         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | <p>Revolution Counter Modulus Enable selects how the revolution counter (REV) is incremented/decremented. By default, the revolution counter is controlled based on the count direction and the INDEX pulse. As an option, the revolution counter can be controlled using the roll-over/under detection during modulo counting.</p> <p>0b - Use INDEX pulse to increment/decrement revolution counter (REV)<br/>1b - Use modulus counting roll-over/under to increment/decrement revolution counter (REV)</p>                                                                                                                                                                                                                   |
| 7-4<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 3<br>LDMOD  | <p>Buffered Register Load (Update) Mode Select</p> <p>This bit selects the loading time point of the buffered compare registers UCOMPx/LCOMPx, x=0~3, initial register (UINIT/LINIT), and modulus register (UMOD/LMOD)</p> <p>0b - Buffered registers are loaded and take effect immediately upon CTRL[LDOCK] is set.<br/>1b - Buffered registers are loaded and take effect at the next roll-over or roll-under if CTRL[LDOCK] is set.</p>                                                                                                                                                                                                                                                                                     |
| 2<br>OPMODE | <p>Operation Mode Select</p> <p>0b - Decode Mode: Input nodes INDEX/PRESET and HOME/ENABLE are assigned to function of INDEX and HOME.</p> <p>1b - Count Mode: Input nodes INDEX/PRESET and HOME/ENABLE are assigned to functions of PRESET and ENABLE. In this mode: (1)only when ENABLE=1, all counters (position/ position difference/revolution/watchdog) can run, when ENABLE=0, all counters (position/position difference/revolution/watchdog) can't run. (2) the rising edge of PRESET input can initialize position/revolution/watchdog counters (position counter initialization also need referring to bit CTRL[REV]).</p>                                                                                           |
| 1<br>UPDPOS | <p>Update Position Registers</p> <ul style="list-style-type: none"> <li>When UPDPOS bit is set (=1), it allows the rising edge of TRIGGER input to clear the POSD, REV, UPOS and LPOS registers to zero.</li> <li>When UPDPOS bit is clear (=0), the rising edge of TRIGGER input does not clear POSD, REV, UPOS and LPOS registers to zero.</li> <li>If both UPDPOS bit and INITPOS bit are set, then when rising edge of TRIGGER input occurs, the UPOS/LPOS registers are not cleared to zero, but be initialized to value of UINIT/LINIT registers(if CTRL[REV]=0) or value of UMOD/LMOD registers(if CTRL[REV]=1).</li> <li>Do not set this bit when using the LASTEDGE and POSDPER registers to measure speed.</li> </ul> |
| 0<br>UPDHLD | <p>Update Hold Registers</p> <ul style="list-style-type: none"> <li>When UPDHLD bit is set (=1), it allows the rising edge of TRIGGER input to cause an update of the POSDH, REVH, UPOSH, and LPOSH registers</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                     |  |         |        |                      |   |   |                                                                  |   |   |                                                                                |   |   |                                                                                                                     |   |   |                                                                                                                     |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|--|---------|--------|----------------------|---|---|------------------------------------------------------------------|---|---|--------------------------------------------------------------------------------|---|---|---------------------------------------------------------------------------------------------------------------------|---|---|---------------------------------------------------------------------------------------------------------------------|
|         | <ul style="list-style-type: none"> <li>When UPDHLD bit is clear (=0), the hold registers (POSDH, REVH) are not updated by the rising edge of TRIGGER input, and hold registers UPOSH/LPOSH are not updated by the rising edge of TRIGGER input if INITPOS bit is also clear.</li> <li>Do not set this bit when using the LASTEDGE and POSDPER registers to measure speed.</li> </ul> <p>UPOSH/LPOSH has little difference with POSDH and REVH on UPDHLD bit, both UPDHLD bit and INITPOS bit allow the rising edge of TRIGGER input to take effect on UPOSH/LPOSH, so make a list here:</p> <table border="1"> <thead> <tr> <th>INITPOS</th> <th>UPDHLD</th> <th>State of UPOSH/LPOSH</th> </tr> </thead> <tbody> <tr> <td>0</td> <td>0</td> <td>Rising edge of TRIGGER input does not take effect on UPOSH/LPOSH</td> </tr> <tr> <td>0</td> <td>1</td> <td>Rising edge of TRIGGER input updates UPOSH/LPOSH with the value of POS counter</td> </tr> <tr> <td>1</td> <td>0</td> <td>Rising edge of TRIGGER input updates UPOSH/LPOSH with the value of POS counter, and then POS counter is initialized</td> </tr> <tr> <td>1</td> <td>1</td> <td>Rising edge of TRIGGER input updates UPOSH/LPOSH with the value of POS counter, and then POS counter is initialized</td> </tr> </tbody> </table> <p>Note: Updating the Position Difference Hold Register (POSDH) also causes the Position Difference Counter Register (POSD) to be cleared.</p> |                                                                                                                     |  | INITPOS | UPDHLD | State of UPOSH/LPOSH | 0 | 0 | Rising edge of TRIGGER input does not take effect on UPOSH/LPOSH | 0 | 1 | Rising edge of TRIGGER input updates UPOSH/LPOSH with the value of POS counter | 1 | 0 | Rising edge of TRIGGER input updates UPOSH/LPOSH with the value of POS counter, and then POS counter is initialized | 1 | 1 | Rising edge of TRIGGER input updates UPOSH/LPOSH with the value of POS counter, and then POS counter is initialized |
| INITPOS | UPDHLD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | State of UPOSH/LPOSH                                                                                                |  |         |        |                      |   |   |                                                                  |   |   |                                                                                |   |   |                                                                                                                     |   |   |                                                                                                                     |
| 0       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Rising edge of TRIGGER input does not take effect on UPOSH/LPOSH                                                    |  |         |        |                      |   |   |                                                                  |   |   |                                                                                |   |   |                                                                                                                     |   |   |                                                                                                                     |
| 0       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Rising edge of TRIGGER input updates UPOSH/LPOSH with the value of POS counter                                      |  |         |        |                      |   |   |                                                                  |   |   |                                                                                |   |   |                                                                                                                     |   |   |                                                                                                                     |
| 1       | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Rising edge of TRIGGER input updates UPOSH/LPOSH with the value of POS counter, and then POS counter is initialized |  |         |        |                      |   |   |                                                                  |   |   |                                                                                |   |   |                                                                                                                     |   |   |                                                                                                                     |
| 1       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Rising edge of TRIGGER input updates UPOSH/LPOSH with the value of POS counter, and then POS counter is initialized |  |         |        |                      |   |   |                                                                  |   |   |                                                                                |   |   |                                                                                                                     |   |   |                                                                                                                     |

### 32.6.1.4 Input Filter Register (FILT)

#### Offset

| Register | Offset |
|----------|--------|
| FILT     | 4h     |

#### Function

The Input Filter Register sets the values of the input filter sample period (FILT\_PER) and the input filter sample count (FILT\_CNT).

- The Input Filter Sample Period (FILT\_PER) should be set so that the sampling period is larger than the period of the expected noise. Doing this means that a noise spike only corrupts one sample.
- The Input Filter Sample Count (FILT\_CNT) should be chosen to reduce the probability of noisy samples causing an incorrect transition to be recognized. The probability of an incorrect transition is defined as the probability of an incorrect sample raised to the power of FILT\_CNT+3.

The values of the Input Filter Sample Period (FILT\_PER) and the Input Filter Sample Count (FILT\_CNT) must also be traded off against the desire for minimal latency in recognizing valid input transitions. Turning on the input filter (setting the Input Filter Sample Period (FILT\_PER) to a non-zero value) introduces a latency of  $((FILT_CNT+3)*FILT\_PER+2)$  IPBus clock periods.

The filter latency can be measured:

- Drive the quadrature decoder inputs (PHASEA, PHASEB, INDEX, HOME)
- Monitor the filtered output in the Input Monitor Register (IMR)
- Determine how many IPBus clock cycles that it takes before the output shows up, by using the following equations, where f is FILT\_PER and s is FILT\_CNT.
  - $\text{DELAY (IPBus clock cycles)} = f * (s+3) + 1$  (to read the filtered output)
  - $\text{DELAY (IPBus clock cycles)} = f * (s+3) + 2$  (to monitor the output in the IMR)

One more additional IPBus clock cycle is needed to read the filtered output, and 2 more IPBus clock cycles are needed to monitor the filtered output in the IMR. The sample rate is set when it reaches the number f. The following examples use the preceding equations:

- Example: when f = 0, the filter is bypassed:  $\text{DELAY} = 1$  or 2 clock cycles.
- Example: when f = 5 and s = 2:  $\text{DELAY} = 5 * (2+3) + (1 \text{ or } 2) = 26$  or 27 clock cycles.

### Diagram

| Bits  | 15   | 14 | 13 | 12 | 11      | 10       | 9 | 8 | 7        | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|------|----|----|----|---------|----------|---|---|----------|---|---|---|---|---|---|---|
| R     | PRSC |    |    |    | FILT_CS | FILT_CNT |   |   | FILT_PER |   |   |   |   |   |   |   |
| W     | 0    | 0  | 0  | 0  | 0       | 0        | 0 | 0 | 0        | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Reset | 0    | 0  | 0  | 0  | 0       | 0        | 0 | 0 | 0        | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

### Fields

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12<br>PRSC    | Prescaler<br><br>The Prescaler field is used to prescale the peripheral clock that is used by the LASTEDGE and POSDPER counters as well as watchdog timer and Input Filter. The clock is prescaled by a value of $2^{\text{PRSC}}$ which means that the prescaler logic can divide the clock by a minimum of 1 and a maximum of 32,768.                                                                    |
| 11<br>FILT_CS    | Filter Clock Source selection<br><br>0b - Peripheral Clock<br>1b - Prescaled peripheral clock by PRSC                                                                                                                                                                                                                                                                                                      |
| 10-8<br>FILT_CNT | Input Filter Sample Count<br><br>The Input Filter Sample Count represents the number of consecutive samples that must agree, before the input filter accepts an input transition. <ul style="list-style-type: none"> <li>• A value of 0x0 represents 3 samples</li> <li>• A value of 0x7 represents 10 samples</li> </ul> The value of the Input Filter Sample Count (FILT_CNT) affects the input latency. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0<br>FILT_PER | <p>Input Filter Sample Period</p> <p>The Input Filter Sample Period represents the sampling period (in IPBus clock cycles) of the decoder input signals. Each input is sampled multiple times at the rate specified by the Input Filter Sample Period.</p> <ul style="list-style-type: none"> <li>If FILT_PER is 0x00 (default), then the input filter is bypassed. Bypassing the digital filter enables the position/position difference counters to operate with count rates up to the IPBus frequency.</li> <li>The value of the Input Filter Sample Period (FILT_PER) affects the input latency.</li> <li>When changing the Input Filter Sample Period (FILT_PER) from a non-zero value to another non-zero value, write a value of 0 first, to clear the filter.</li> </ul> |

### 32.6.1.5 Last Edge Time Register (LASTEDGE)

#### Offset

| Register | Offset |
|----------|--------|
| LASTEDGE | 6h     |

#### Diagram



#### Fields

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0<br>LASTEDGE | <p>Last Edge Time Counter</p> <p>The Last Edge Time counter represents the time since the last edge occurred on PHASEA or PHASEB. LASTEDGE counts up using the peripheral clock that is prescaled by FILT[PRSC]. Any edge on PHASEA or PHASEB resets this register to 0 and starts counting. If the LASTEDGE count reaches 0xffff, the counting stops in order to prevent an overflow. Counting continues when an edge occurs on PHASEA or PHASEB.</p> |

### 32.6.1.6 Position Difference Period Counter Register (POSDPER)

#### Offset

| Register | Offset |
|----------|--------|
| POSDPER  | 8h     |

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---------|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |   |   | POSDPER |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |   |   |         |   |   |   |   |   |   |   |
| Reset | 1  | 1  | 1  | 1  | 1  | 1  | 1 | 1 | 1       | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

**Fields**

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0<br>POSDPER | Position difference period<br><br>The Position Difference Period counter counts up using the peripheral clock that is prescaled by FILT[PRSC]. Reading the POSD register also causes the value of the LASTEDGE register to be loaded into POSDPER. If the POSDPER count reaches 0xffff, the counting stops in order to prevent an overflow. Counting continues when an edge occurs on PHASEA or PHASEB. |

**32.6.1.7 Position Difference Period Buffer Register (POSDPERBFR)****Offset**

| Register   | Offset |
|------------|--------|
| POSDPERBFR | Ah     |

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7          | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|------------|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |   |   | POSDPERBFR |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |   |   |            |   |   |   |   |   |   |   |
| Reset | 1  | 1  | 1  | 1  | 1  | 1  | 1 | 1 | 1          | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

**Fields**

| Field              | Function                                                                                                                                                                                                                      |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0<br>POSDPERBFR | Position difference period buffer<br><br>The Position Difference Period buffer register is a buffer register for the POSDPER value. POSDPERBFR is updated with the value of POSDPER when any edge occurs on PHASEA or PHASEB. |

**32.6.1.8 Upper Position Counter Register (UPOS)****Offset**

| Register | Offset |
|----------|--------|
| UPOS     | Ch     |

**Function**

Contains the upper (most significant) half of the Position Counter. This is the binary count from the Position Counter.

**Diagram****Fields**

| Field | Function                                                  |
|-------|-----------------------------------------------------------|
| 15-0  | POS                                                       |
| POS   | The upper (most significant) half of the Position Counter |

**32.6.1.9 Lower Position Counter Register (LPOS)****Offset**

| Register | Offset |
|----------|--------|
| LPOS     | Eh     |

**Function**

Contains the lower (least significant) half of the Position Counter. This is the binary count from the Position Counter.

**Diagram****Fields**

| Field | Function                                                   |
|-------|------------------------------------------------------------|
| 15-0  | POS                                                        |
| POS   | The lower (least significant) half of the Position Counter |

### 32.6.1.10 Position Difference Counter Register (POSD)

#### Offset

| Register | Offset |
|----------|--------|
| POSD     | 10h    |

#### Function

The Position Difference Counter Register contains the position change in value occurring between each read of the Position Register. The value of the Position Difference Counter Register can be used to calculate velocity.

- The 16-bit Position Difference Counter computes up or down on every count pulse.
- This Position Difference Counter acts as a differentiator, whose count value is proportional to the change in position since the last time that the Position Counter was read.
- When the Position Difference Counter (POSD) is read, its contents are copied into the Position Difference Hold Register (POSDH) and the Position Difference Counter is cleared.

#### Diagram



#### Fields

| Field | Function                                                                 |
|-------|--------------------------------------------------------------------------|
| 15-0  | POSD                                                                     |
| POSD  | The position change in value between each read of the Position Register. |

### 32.6.1.11 Position Difference Hold Register (POSDH)

#### Offset

| Register | Offset |
|----------|--------|
| POSDH    | 12h    |

#### Function

The Position Difference Hold Register register contains a snapshot of the value of the Position Difference Counter Register (POSD). The value of the Position Difference Hold Register (POSDH) can be used to calculate velocity.

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|-------|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |   |   | POSDH |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |   |   |       |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Fields**

| Field | Function                       |
|-------|--------------------------------|
| 15-0  | POSDH                          |
| POSDH | The value of the POSD register |

**32.6.1.12 Upper Position Hold Register (UPOSH)****Offset**

| Register | Offset |
|----------|--------|
| UPOSH    | 14h    |

**Function**

Contains a snapshot of the Upper Position Counter Register (UPOS register).

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |   |   | POSH |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0    | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Fields**

| Field | Function                                                      |
|-------|---------------------------------------------------------------|
| 15-0  | POSH                                                          |
| POSH  | The value of the Upper Position Counter Hold Register (UPOSH) |

**32.6.1.13 Lower Position Hold Register (LPOSH)****Offset**

| Register | Offset |
|----------|--------|
| LPOSH    | 16h    |

**Function**

Contains a snapshot of the Lower Position Counter Register (LPOS).

**Diagram****Fields**

| Field | Function                                                      |
|-------|---------------------------------------------------------------|
| 15-0  | POSH                                                          |
| LPOSH | The value of the Lower Position Counter Hold Register (LPOSH) |

**32.6.1.14 Last Edge Time Hold Register (LASTEDGEH)****Offset**

| Register  | Offset |
|-----------|--------|
| LASTEDGEH | 18h    |

**Diagram****Fields**

| Field     | Function                                                                                                                                                    |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0      | Last Edge Time Hold                                                                                                                                         |
| LASTEDGEH | The Last Edge Time Hold register is a hold register for the LASTEDGE value. LASTEDGEH is updated with the value of LASTEDGE when the POSD register is read. |

### 32.6.1.15 Position Difference Period Hold Register (POSDPERH)

#### Offset

| Register | Offset |
|----------|--------|
| POSDPERH | 1Ah    |

#### Diagram



#### Fields

| Field            | Function                                                                                                                                                                                                       |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0<br>POSDPERH | Position difference period hold<br><br>The Position Difference Period Hold register is a hold register for the POSDPER value. POSDPERH is updated with the value of POSDPERBFR when the POSD register is read. |

### 32.6.1.16 Revolution Hold Register (REVH)

#### Offset

| Register | Offset |
|----------|--------|
| REVH     | 1Ch    |

#### Function

Contains a snapshot of the value of the Revolution Counter Register (REV).

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|------|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |   |   | REVH |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |   |   |      |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0    | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Fields**

| Field | Function                                           |
|-------|----------------------------------------------------|
| 15-0  | REVH                                               |
| REVH  | The value of the Revolution Counter Register (REV) |

**32.6.1.17 Revolution Counter Register (REV)****Offset**

| Register | Offset |
|----------|--------|
| REV      | 1Eh    |

**Function**

Contains the current value of the Revolution Counter.

**Diagram**

| Bits | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7   | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----|----|----|----|----|----|---|---|-----|---|---|---|---|---|---|---|
| R    |    |    |    |    |    |    |   |   | REV |   |   |   |   |   |   |   |
| W    |    |    |    |    |    |    |   |   |     |   |   |   |   |   |   |   |

**Fields**

| Field | Function                                    |
|-------|---------------------------------------------|
| 15-0  | REV                                         |
| REV   | The current value of the Revolution Counter |

**32.6.1.18 Upper Initialization Register (UINIT)****Offset**

| Register | Offset |
|----------|--------|
| UINIT    | 20h    |

**Function**

Contains the value to be used to initialize the upper half of the position counter (UPOS). It is a double-set register (please refer to chapter "Double-set Registers Loading Operation"). Writing this register actually writes to the out-set, and reading this register returns inner-set value which is the value that is taking effect.

**Diagram****Fields**

| Field | Function                                                                          |
|-------|-----------------------------------------------------------------------------------|
| 15-0  | INIT                                                                              |
| INIT  | The value to be used to initialize the upper half of the position counter (UPOS). |

**32.6.1.19 Lower Initialization Register (LINIT)****Offset**

| Register | Offset |
|----------|--------|
| LINIT    | 22h    |

**Function**

Contains the value to be used to initialize the lower half of the position counter (LPOS). It is a double-set register (please refer to chapter "Double-set Registers Loading Operation"). Writing this register actually writes to the out-set, and reading this register returns inner-set value which is the value that is taking effect.

**Diagram****Fields**

| Field | Function                                                                         |
|-------|----------------------------------------------------------------------------------|
| 15-0  | INIT                                                                             |
| INIT  | The value to be used to initialize the lower half of the position counter (LPOS) |

### 32.6.1.20 Upper Modulus Register (UMOD)

#### Offset

| Register | Offset |
|----------|--------|
| UMOD     | 24h    |

#### Function

The Upper Modulus Register contains the upper (most significant) half of the Modulus register. MOD acts as the upper bound during modulo counting, and as the upper reload value when rolling over from the lower bound. It is a double-set register (please refer to chapter "Double-set Registers Loading Operation"). Writing this register actually writes to the out-set, and reading this register returns inner-set value which is the value that is taking effect.

#### Diagram



#### Fields

| Field | Function                                              |
|-------|-------------------------------------------------------|
| 15-0  | MOD                                                   |
| MOD   | Upper (most significant) half of the Modulus register |

### 32.6.1.21 Lower Modulus Register (LMOD)

#### Offset

| Register | Offset |
|----------|--------|
| LMOD     | 26h    |

#### Function

The Lower Modulus Register contains the lower (least significant) half of the Modulus register. MOD acts as the upper bound during modulo counting, and as the upper reload value when rolling over from the lower bound. It is a double-set register (please refer to chapter "Double-set Registers Loading Operation"). Writing this register actually writes to the out-set, and reading this register returns inner-set value which is the value that is taking effect.

**Diagram****Fields**

| Field | Function                                               |
|-------|--------------------------------------------------------|
| 15-0  | MOD                                                    |
| MOD   | Lower (least significant) half of the Modulus register |

**32.6.1.22 Upper Position Compare Register 0 (UCOMP0)****Offset**

| Register | Offset |
|----------|--------|
| UCOMP0   | 28h    |

**Function**

The Upper Position Compare Register contains the upper (most significant) half of the Position Compare register 0. When the value of the Position counter (POS) matches the value of the Position Compare register 0(COMP0), the Compare Interrupt Request flag (INTCTRL[CMP0IRQ]) is set and the POS\_MATCH[0] output is asserted. COMP\_FLG[0] is asserted when the Position Counter is equal or greater than COMP0. COMP\_FLG[0] is de-asserted when the Position Counter is less than COMP0. Note: If COMP0 value equals initial value (INIT) or modulus value (MOD), COMP\_FLG[0] does not take effect. It is a double-set register (please refer to chapter "Double-set Registers Loading Operation"). Writing this register actually writes to the out-set, and reading this register returns inner-set value which is the value that is taking effect.

**Diagram****Fields**

| Field  | Function                                                         |
|--------|------------------------------------------------------------------|
| 15-0   | UCOMP0                                                           |
| UCOMP0 | Upper (most significant) half of the Position Compare register 0 |

### 32.6.1.23 Lower Position Compare Register 0 (LCOMP0)

#### Offset

| Register | Offset |
|----------|--------|
| LCOMP0   | 2Ah    |

#### Function

The Lower Position Compare Register contains the lower (least significant) half of the Position Compare register 0. When the value of the Position counter (POS) matches the value of the Position Compare register 0(COMP0), the Compare Interrupt Request flag (INTCTRL[ CMP0IRQ]) is set and the POS\_MATCH[0] output is asserted. COMP\_FLG[0] is asserted when the Position Counter is equal or greater than COMP0. COMP\_FLG[0] is de-asserted when the Position Counter is less than COMP0. Note: If COMP0 value equals initial value (INIT) or modulus value (MOD), COMP\_FLG[0] does not take effect. It is a double-set register (please refer to chapter "Double-set Registers Loading Operation"). Writing this register actually writes to the out-set, and reading this register returns inner-set value which is the value that is taking effect.

#### Diagram



#### Fields

| Field  | Function                                                          |
|--------|-------------------------------------------------------------------|
| 15-0   | LCOMP0                                                            |
| LCOMP0 | Lower (least significant) half of the Position Compare register 0 |

### 32.6.1.24 Upper Position Compare 1 (UCOMP1)

#### Offset

| Register | Offset |
|----------|--------|
| UCOMP1   | 2Ch    |

#### Function

The Upper Position Compare Register contains the upper (most significant) half of the Position Compare register 1. When the value of the Position counter (POS) matches the value of the Position Compare register 1 (COMP1), the Compare Interrupt Request flag (INTCTRL[ CMP1IRQ]) is set and the POS\_MATCH[1] output is asserted. COMP\_FLG[1] is asserted when the Position Counter is equal or greater than COMP1. COMP\_FLG[1] is de-asserted when the Position Counter is less than COMP1. Note: If COMP1 value equals initial value (INIT) or modulus value (MOD), COMP\_FLG[1] does not take effect. It is a double-set register (please refer to chapter "Double-set Registers Loading Operation"). Writing this register actually writes to the out-set.

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 1  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Fields**

| Field  | Function                                                                                |
|--------|-----------------------------------------------------------------------------------------|
| 15-0   | UCOMP1                                                                                  |
| UCOMP1 | When write, it writes Upper (most significant) half of the Position Compare register 1. |

**32.6.1.25 Upper Position Holder Register 1 (UPOSH1)****Offset**

| Register | Offset |
|----------|--------|
| UPOSH1   | 2Ch    |

**Function**

UPOSH1 share the same address with UCOMP1. When read, this register means the value of the Upper Position Counter Hold Register 1(UPOSH1), which is the upper 16 bits of POSH1. Position counter is captured into POSH1 on the rising edge of ICAP[1].

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Fields**

| Field  | Function                                                                            |
|--------|-------------------------------------------------------------------------------------|
| 15-0   | UPOSH1                                                                              |
| UPOSH1 | When read, it means the value of the Upper Position Hold Counter Register 1(UPOSH1) |

### 32.6.1.26 Lower Position Compare 1 (LCOMP1)

#### Offset

| Register | Offset |
|----------|--------|
| LCOMP1   | 2Eh    |

#### Function

The Lower Position Compare Register contains the upper (most significant) half of the Position Compare register 1. When the value of the Position counter (POS) matches the value of the Position Compare register 1 (COMP1), the Compare Interrupt Request flag (INTCTRL[CMP1IRQ]) is set and the POS\_MATCH[1] output is asserted. COMP\_FLG[1] is asserted when the Position Counter is equal or greater than COMP1. COMP\_FLG[1] is de-asserted when the Position Counter is less than COMP1. Note: If COMP1 value equals initial value (INIT) or modulus value (MOD), COMP\_FLG[1] does not take effect. It is a double-set register (please refer to chapter "Double-set Registers Loading Operation"). Writing this register actually writes to the out-set.

#### Diagram



#### Fields

| Field  | Function                                                                                |
|--------|-----------------------------------------------------------------------------------------|
| 15-0   | LCOMP1                                                                                  |
| LCOMP1 | When write, it writes Lower (most significant) half of the Position Compare register 1. |

### 32.6.1.27 Lower Position Holder Register 1 (LPOSH1)

#### Offset

| Register | Offset |
|----------|--------|
| LPOSH1   | 2Eh    |

#### Function

LPOSH1 share the same address with LCOMP1. When read, this register means the value of the Lower Position Counter Hold Register 1(LPOSH1), which is the lower 16 bits of POSH1. Position counter is captured into POSH1 on the rising edge of ICAP[1].

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|--------|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |   |   | LPOSH1 |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |   |   |        |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0      | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Fields**

| Field  | Function                                                                            |
|--------|-------------------------------------------------------------------------------------|
| 15-0   | LPOSH1                                                                              |
| LPOSH1 | When read, it means the value of the Lower Position Counter Hold Register 1(LPOSH1) |

**32.6.1.28 Upper Position Compare 2 (UCOMP2)****Offset**

| Register | Offset |
|----------|--------|
| UCOMP2   | 30h    |

**Function**

The Upper Position Compare Register contains the upper (most significant) half of the Position Compare register 2. When the value of the Position counter (POS) matches the value of the Position Compare register 2 (COMP2), the Compare Interrupt Request flag (INTCTRL[COMP2IRQ]) is set and the POS\_MATCH[2] output is asserted. COMP\_FLG[2] is asserted when the Position Counter is equal or greater than COMP2. COMP\_FLG[2] is de-asserted when the Position Counter is less than COMP2. Note: If COMP2 value equals initial value (INIT) or modulus value (MOD), COMP\_FLG[2] does not take effect. It is a double-set register (please refer to chapter "Double-set Registers Loading Operation"). Writing this register actually writes to the out-set.

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|--------|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |   |   |        |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |   |   | UCOMP2 |   |   |   |   |   |   |   |
| Reset | 1  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0      | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Fields**

| Field  | Function                                                                                |
|--------|-----------------------------------------------------------------------------------------|
| 15-0   | UCOMP2                                                                                  |
| UCOMP2 | When write, it writes Upper (most significant) half of the Position Compare register 2. |

### 32.6.1.29 Upper Position Holder Register 3 (UPOSH2)

#### Offset

| Register | Offset |
|----------|--------|
| UPOSH2   | 30h    |

#### Function

UPOSH2 share the same address with UCOMP2. When read, this register means the value of the Upper Position Counter Hold Register 2(UPOSH2), which is the upper 16 bits of POSH2. Position counter is captured into POSH2 on the rising edge of ICAP[2].

#### Diagram



#### Fields

| Field  | Function                                                                            |
|--------|-------------------------------------------------------------------------------------|
| 15-0   | UPOSH2                                                                              |
| UPOSH2 | When read, it means the value of the Upper Position Counter Hold Register 2(UPOSH2) |

### 32.6.1.30 Lower Position Compare 2 (LCOMP2)

#### Offset

| Register | Offset |
|----------|--------|
| LCOMP2   | 32h    |

#### Function

The Lower Position Compare Register contains the Lower (most significant) half of the Position Compare register 2. When the value of the Position counter (POS) matches the value of the Position Compare register 2 (COMP2), the Compare Interrupt Request flag (INTCTRL[CMP2IRQ]) is set and the POS\_MATCH[2] output is asserted. COMP\_FLG[2] is asserted when the Position Counter is equal or greater than COMP2. COMP\_FLG[2] is de-asserted when the Position Counter is less than COMP2. Note: If COMP2 value equals initial value (INIT) or modulus value (MOD), COMP\_FLG[2] does not take effect. It is a double-set register (please refer to chapter "Double-set Registers Loading Operation"). Writing this register actually writes to the out-set.

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Fields**

| Field  | Function                                                                                |
|--------|-----------------------------------------------------------------------------------------|
| 15-0   | LCOMP2                                                                                  |
| LCOMP2 | When write, it writes Lower (most significant) half of the Position Compare register 2. |

**32.6.1.31 Lower Position Holder Register 2 (LPOSH2)****Offset**

| Register | Offset |
|----------|--------|
| LPOSH2   | 32h    |

**Function**

LPOSH2 share the same address with LCOMP2. When read, this register means the value of the Lower Position Counter Hold Register 2 (LPOSH2), which is the lower 16 bits of POSH2. Position counter is captured into POSH2 on the rising edge of ICAP[2].

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Fields**

| Field  | Function                                                                             |
|--------|--------------------------------------------------------------------------------------|
| 15-0   | LPOSH2                                                                               |
| LPOSH2 | When read, it means the value of the Lower Position Counter Hold Register 2 (LPOSH2) |

### 32.6.1.32 Upper Position Compare 3 (UCOMP3)

#### Offset

| Register | Offset |
|----------|--------|
| UCOMP3   | 34h    |

#### Function

The Upper Position Compare Register contains the upper (most significant) half of the Position Compare register 3. When the value of the Position counter (POS) matches the value of the Position Compare register 3 (COMP3), the Compare Interrupt Request flag (INTCTRL[CMP3IRQ]) is set and the POS\_MATCH[3] output is asserted. COMP\_FLG[3] is asserted when the Position Counter is equal or greater than COMP3. COMP\_FLG[3] is de-asserted when the Position Counter is less than COMP3. Note: If COMP3 value equals initial value (INIT) or modulus value (MOD), COMP\_FLG[3] does not take effect. It is a double-set register (please refer to chapter "Double-set Registers Loading Operation"). Writing this register actually writes to the out-set.

#### Diagram



#### Fields

| Field          | Function                                                                                |
|----------------|-----------------------------------------------------------------------------------------|
| 15-0<br>UCOMP3 | When write, it writes Upper (most significant) half of the Position Compare register 3. |

### 32.6.1.33 Upper Position Holder Register 3 (UPOSH3)

#### Offset

| Register | Offset |
|----------|--------|
| UPOSH3   | 34h    |

#### Function

UPOSH3 share the same address with UCOMP3. When read, this register means the value of the Upper Position Counter Hold Register 3 (UPOSH3), which is the upper 16 bits of POSH3. Position counter is captured into POSH3 on the rising edge of ICAP[3].

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|--------|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |   |   | UPOSH3 |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |   |   |        |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0      | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Fields**

| Field  | Function                                                                            |
|--------|-------------------------------------------------------------------------------------|
| 15-0   | UPOSH3                                                                              |
| UPOSH3 | When read, it means the value of the Upper Position Counter Hold Register 3(UPOSH3) |

**32.6.1.34 Lower Position Compare 3 (LCOMP3)****Offset**

| Register | Offset |
|----------|--------|
| LCOMP3   | 36h    |

**Function**

The Lower Position Compare Register contains the Lower (most significant) half of the Position Compare register 3. When the value of the Position counter (POS) matches the value of the Position Compare register 3 (COMP3), the Compare Interrupt Request flag (INTCTRL[ CMP3IRQ]) is set and the POS\_MATCH[3] output is asserted. COMP\_FLG[3] is asserted when the Position Counter is equal or greater than COMP3. COMP\_FLG[3] is de-asserted when the Position Counter is less than COMP3. Note: If COMP3 value equals initial value (INIT) or modulus value (MOD), COMP\_FLG[3] does not take effect. It is a double-set register (please refer to chapter "Double-set Registers Loading Operation"). Writing this register actually writes to the out-set.

**Diagram**

| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7      | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----|----|----|----|----|----|---|---|--------|---|---|---|---|---|---|---|
| R     |    |    |    |    |    |    |   |   |        |   |   |   |   |   |   |   |
| W     |    |    |    |    |    |    |   |   | LCOMP3 |   |   |   |   |   |   |   |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0      | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Fields**

| Field  | Function                                                                                |
|--------|-----------------------------------------------------------------------------------------|
| 15-0   | LCOMP3                                                                                  |
| LCOMP3 | When write, it writes Lower (most significant) half of the Position Compare register 3. |

### 32.6.1.35 Lower Position Holder Register 3 (LPOSH3)

#### Offset

| Register | Offset |
|----------|--------|
| LPOSH3   | 36h    |

#### Function

When read, this register means the value of the Lower Position Counter Register 3 (LPOS)

#### Diagram



#### Fields

| Field  | Function                                                                                                                                                                                                                               |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0   | LPOSH3                                                                                                                                                                                                                                 |
| LPOSH3 | LPOSH3 share the same address with LCOMP3. When read, it means the value of the Lower Position Counter Register 3 (LPOS3), which is the lower 16 bits of POSH3. Position counter is captured into POSH3 on the rising edge of ICAP[3]. |

### 32.6.1.36 Interrupt Control Register (INTCTRL)

#### Offset

| Register | Offset |
|----------|--------|
| INTCTRL  | 38h    |

**Diagram**

| Bits  | 15          | 14         | 13          | 12         | 11          | 10         | 9           | 8          | 7         | 6    | 5         | 4    | 3          | 2     | 1          | 0     |
|-------|-------------|------------|-------------|------------|-------------|------------|-------------|------------|-----------|------|-----------|------|------------|-------|------------|-------|
| R     | CMP3I<br>RQ | CMP3I<br>E | CMP2I<br>RQ | CMP2I<br>E | CMP1I<br>RQ | CMP1I<br>E | CMP0I<br>RQ | CMP0I<br>E | ROIR<br>Q | ROIE | RUIR<br>Q | RUIE | DIRIR<br>Q | DIRIE | SABIR<br>Q | SABIE |
| W     | W1C         | W1C        | W1C         | W1C        | W1C         | W1C        | W1C         | W1C        | W1C       | W1C  | W1C       | W1C  | W1C        | W1C   | W1C        | W1C   |
| Reset | 0           | 0          | 0           | 0          | 0           | 0          | 0           | 0          | 0         | 0    | 0         | 0    | 0          | 0     | 0          | 0     |

**Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>CMP3IRQ | Compare3 Interrupt Request<br><br>Compare3 Interrupt Request is set when the position counter matches the COMP3 value. <ul style="list-style-type: none"><li>• Compare3 Interrupt Request remains set until cleared by software</li><li>• Write 1 to this bit (CMP3IRQ) to clear it<ul style="list-style-type: none"><li>0b - No match has occurred (the position counter does not match the COMP3 value)</li><li>1b - COMP3 match has occurred (the position counter matches the COMP3 value)</li></ul></li></ul> |
| 14<br>CMP3IE  | Compare3 Interrupt Enable<br><br>Enables/disables compare3 interrupt. <ul style="list-style-type: none"><li>0b - Disabled</li><li>1b - Enabled</li></ul>                                                                                                                                                                                                                                                                                                                                                           |
| 13<br>CMP2IRQ | Compare2 Interrupt Request<br><br>Compare2 Interrupt Request is set when the position counter matches the COMP2 value. <ul style="list-style-type: none"><li>• Compare2 Interrupt Request remains set until cleared by software</li><li>• Write 1 to this bit (CMP2IRQ) to clear it<ul style="list-style-type: none"><li>0b - No match has occurred (the position counter does not match the COMP2 value)</li><li>1b - COMP2 match has occurred (the position counter matches the COMP2 value)</li></ul></li></ul> |
| 12<br>CMP2IE  | Compare2 Interrupt Enable<br><br>Enables/disables compare2 interrupts. <ul style="list-style-type: none"><li>0b - Disabled</li><li>1b - Enabled</li></ul>                                                                                                                                                                                                                                                                                                                                                          |
| 11<br>CMP1IRQ | Compare1 Interrupt Request<br><br>Compare1 Interrupt Request is set when the position counter matches the COMP1 value. <ul style="list-style-type: none"><li>• Compare1 Interrupt Request remains set until cleared by software</li><li>• Write 1 to this bit (CMP1IRQ) to clear it<ul style="list-style-type: none"><li>0b - No match has occurred (the position counter does not match the COMP1 value)</li><li>1b - COMP1 match has occurred (the position counter matches the COMP1 value)</li></ul></li></ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10<br>CMP1IE | Compare1 Interrupt Enable<br><br>Enables/disables compare1 interrupt.<br><br>0b - Disabled<br>1b - Enabled                                                                                                                                                                                                                                                                                                                                                     |
| 9<br>CMP0IRQ | Compare 0 Interrupt Request<br><br>Compare 0 Interrupt Request is set when the position counter matches the COMP0 value. <ul style="list-style-type: none"><li>• Compare Interrupt Request remains set until cleared by software</li><li>• Write 1 to this bit (CMP0IRQ) to clear it</li></ul> 0b - No match has occurred (the position counter does not match the COMP0 value)<br>1b - COMP match has occurred (the position counter matches the COMP0 value) |
| 8<br>CMP0IE  | Compare 0 Interrupt Enable<br><br>Enables/disables compare 0 interrupts.<br><br>0b - Disabled<br>1b - Enabled                                                                                                                                                                                                                                                                                                                                                  |
| 7<br>ROIRQ   | Roll-over Interrupt Request<br><br>Roll-over Interrupt Request bit is set (=1) when the position counter (POS) value is greater than the modulus value, which means roll-over. <ul style="list-style-type: none"><li>• Roll-over Interrupt Request remains set until cleared by software</li><li>• Write a one to this bit (ROIRQ) to clear it</li></ul> 0b - No roll-over has occurred<br>1b - Roll-over has occurred                                         |
| 6<br>ROIE    | Roll-over Interrupt Enable<br><br>Roll-over Interrupt Enable read/write bit enables roll-over interrupts, based on Roll-under Interrupt Request (INTCTRL[ROIRQ]) being set.<br><br>0b - Disabled<br>1b - Enabled                                                                                                                                                                                                                                               |
| 5<br>RUIRQ   | Roll-under Interrupt Request<br><br>Roll-under Interrupt Request bit is set (=1) when the position counter (POS) value less than initial value, which means roll-under <ul style="list-style-type: none"><li>• Roll-under Interrupt Request remains set until cleared by software</li><li>• Write a one to this bit (RUIRQ) to clear it</li></ul> 0b - No roll-under has occurred<br>1b - Roll-under has occurred                                              |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4<br>RUIE   | <p>Roll-under Interrupt Enable</p> <p>Roll-under Interrupt Enable read/write bit enables roll-under interrupts, based on the Roll-over Interrupt Request bit (INTCTRL[RUIRQ]) being set.</p> <p>0b - Disabled<br/>1b - Enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 3<br>DIRIRQ | <p>Count direction change interrupt</p> <p>Count direction change interrupt bit is set(=1) when POS/POSD/REV counter count direction changes, which means IMR[DIR] changes from 0 to 1 or from 1 to 0</p> <p>0b - Count direction unchanged<br/>1b - Count direction changed</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 2<br>DIRIE  | <p>Count direction change interrupt enable</p> <p>Count direction change interrupt enable interrupt</p> <p>0b - Disabled<br/>1b - Enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1<br>SABIRQ | <p>Simultaneous PHASEA and PHASEB Change Interrupt Request</p> <p>Simultaneous PHASEA and PHASEB Change Interrupt Request indicates that the PHASEA and PHASEB inputs changed simultaneously (within a single clock period). This event typically indicates an error condition, because quadrature coding requires only one of these inputs to change at a time.</p> <ul style="list-style-type: none"> <li>• Simultaneous PHASEA and PHASEB Change Interrupt Request bit remains set until it is cleared by software or a reset</li> <li>• Write 1 to this bit (SABIRQ) to clear it</li> </ul> <p>0b - No simultaneous change of PHASEA and PHASEB has occurred<br/>1b - A simultaneous change of PHASEA and PHASEB has occurred</p> |
| 0<br>SABIE  | <p>Simultaneous PHASEA and PHASEB Change Interrupt Enable</p> <p>Simultaneous PHASEA and PHASEB Change Interrupt Enable bit enables simultaneous PHASEA and PHASEB change interrupts, based on the Simultaneous PHASEA and PHASEB Change Interrupt Request (SABIRQ) bit being set.</p> <p>0b - Disabled<br/>1b - Enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                          |

### 32.6.1.37 Watchdog Timeout Register (WTR)

#### Offset

| Register | Offset |
|----------|--------|
| WTR      | 3Ah    |

**Function**

The Watchdog Timeout Register stores the timeout count for the quadrature decoder module watchdog timer. This quadrature decoder module watchdog timer is separate from any other watchdog timer(s) that may also be in the device.

**Diagram**

| Bits | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| R    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| W    |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

  

| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|-------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|-------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|

**Fields**

| Field | Function                                                                                                                                                                                          |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0  | WDOG                                                                                                                                                                                              |
| WDOG  | WDOG[15:0] is a binary representation of the number of clock cycles, using the peripheral clock prescaled by FILT[PRSC], 0xFFFF plus one count in this register determines the timing out period. |

**32.6.1.38 Input Monitor Register (IMR)****Offset**

| Register | Offset |
|----------|--------|
| IMR      | 3Ch    |

**Function**

The Input Monitor Register contains the values of the raw and filtered PHASEA, PHASEB, INDEX/PRESET and HOME/ENABLE input signals. The reset value depends on the values of the raw and filtered values of PHASEA, PHASEB, INDEX/PRESET and HOME/ENABLE input signals:

- The Input Monitor Register [3:0] contains the values of the raw value of PHASEA, PHASEB, INDEX/PRESET and HOME/ENABLE input signals.
- The Input Monitor Register [7:4] contains the values of the filtered value of PHASEA, PHASEB, INDEX/PRESET and HOME/ENABLE input signals.
- The Input Monitor Register [7:4] supply filter bypass function for PHASEA, PHASEB, INDEX/PRESET and HOME/ENABLE input signals.
- The Input Monitor Register [11:8] contains the values of the 4 POS counter CMPs flag.
- The Input Monitor Register [15:14] contains the values of the count direction flag and count direction flag hold.
- If no pull-up or pull-down is connected to PHASEA, PHASEB, INDEX/PRESET and HOME/ENABLE input signals, then the reset value of the 4 lower bits of the Input Monitor Register (IMR) are all unknown.

**Diagram**

| Bits  | 15  | 14   | 13 | 12    | 11    | 10    | 9     | 8 | 7    | 6    | 5        | 4        | 3   | 2   | 1          | 0          |
|-------|-----|------|----|-------|-------|-------|-------|---|------|------|----------|----------|-----|-----|------------|------------|
| R     | DIR | DIRH | 0  | CMP3F | CMP2F | CMP1F | CMPF0 |   | FPHA | FPHB | FIND_PRE | FHOM_ENA | PHA | PHB | INDEX_P... | HOME_EN... |
| W     |     |      |    |       |       |       |       |   |      |      |          |          |     |     |            |            |
| Reset | 0   | 0    | 0  | 0     | 0     | 0     | 0     | 0 | 0    | 0    | 0        | 0        | 0   | 0   | 0          | 0          |

**Fields**

| Field       | Function                                                                                                                                                                                                                  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>DIR   | Count Direction Flag Output<br><br>The Count Direction Flag indicates the direction of the current count.<br><br>0b - Current count was in the down direction<br>1b - Current count was in the up direction               |
| 14<br>DIRH  | Count Direction Flag Hold<br><br>DIRH contains a snapshot of the DIR when initializing POS                                                                                                                                |
| 13-12<br>—  | Reserved                                                                                                                                                                                                                  |
| 11<br>CMP3F | Position Compare3 Flag Output<br><br>Flag of compare3<br><br>0b - When the position counter value is less than value of COMP3 register<br>1b - When the position counter is greater or equal than value of COMP3 register |
| 10<br>CMP2F | Position Compare2 Flag Output<br><br>Flag of compare2<br><br>0b - When the position counter is less than value of COMP2 register<br>1b - When the position counter is greater or equal than value of COMP2 register       |
| 9<br>CMP1F  | Position Compare1 Flag Output<br><br>Flag of compare1<br><br>0b - When the position counter is less than value of COMP1 register<br>1b - When the position counter is greater or equal than value of COMP1 register       |
| 8<br>CMPF0  | Position Compare 0 Flag Output<br><br>Flag of compare 0<br><br>0b - When the position counter is less than value of COMP0 register<br>1b - When the position counter is greater or equal than value of COMP0 register     |
| 7           | filter operation on PHASEA input                                                                                                                                                                                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                       |
|--------------|--------------------------------------------------------------------------------------------------------------------------------|
| FPHA         | When write 1, it means filter for PHASEA input is bypassed<br>When read, it shows filtered version of PHASEA input             |
| 6            | filter operation on PHASEB input                                                                                               |
| FPHB         | When write 1, it means filter for PHASEB input is bypassed<br>When read, it shows filtered version of PHASEB input             |
| 5            | filter operation on INDEX/PRESET input                                                                                         |
| FIND_PRE     | When write 1, it means filter for INDEX/PRESET input is bypassed<br>When read, it shows filtered version of INDEX/PRESET input |
| 4            | filter operation on HOME/ENABLE input                                                                                          |
| FHOM_ENA     | When write 1, it means filter for HOME/ENABLE input is bypassed<br>When read, it shows filtered version of HOME/ENABLE input   |
| 3            | PHA                                                                                                                            |
| PHA          | Raw PHASEA input                                                                                                               |
| 2            | PHB                                                                                                                            |
| PHB          | Raw PHASEB input                                                                                                               |
| 1            | INDEX_PRESET                                                                                                                   |
| INDEX_PRESET | Raw INDEX/PRESET input                                                                                                         |
| 0            | HOME_ENABLE                                                                                                                    |
| HOME_ENABLE  | The raw HOME/ENABLE input                                                                                                      |

### 32.6.1.39 Test Register (TST)

#### Offset

| Register | Offset |
|----------|--------|
| TST      | 3Eh    |

#### Function

The Test Register controls and sets the frequency of a quadrature signal generator; it provides a quadrature test signal to the inputs of the quadrature decoder module.

- The TEST\_COUNT value is counted down to zero when the test module is enabled (TEN = 1) and the counter is enabled (TCE = 1).

- Each count value of one represents a single quadrature cycle interpreted as a count of one by the position counter (UPOS and LPOS) if it is enabled (TEN = 1, TCE = 1).
- Repeated writing of new values to TEST\_COUNT can cause an extra phase transition and therefore an extra count by the Position Counter.
- The period field determines the length (in IPBus clock cycles) of each quadrature cycle phase.

The Test Register is a factory test feature; however, it can also be useful in customer software development and testing.

### Diagram

| Bits  | 15  | 14  | 13  | 12          | 11 | 10 | 9 | 8          | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-----|-----|-----|-------------|----|----|---|------------|---|---|---|---|---|---|---|---|
| R     | TEN | TCE | QDN | TEST_PERIOD |    |    |   | TEST_COUNT |   |   |   |   |   |   |   |   |
| W     | 0   | 0   | 0   | 0           | 0  | 0  | 0 | 0          | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Reset | 0   | 0   | 0   | 0           | 0  | 0  | 0 | 0          | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

### Fields

| Field               | Function                                                                                                                                                                                                                           |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>TEN           | Test Mode Enable<br>Connects the test module to inputs of the quadrature decoder module.<br>0b - Disabled<br>1b - Enabled                                                                                                          |
| 14<br>TCE           | Test Counter Enable<br>Connects the test counter to inputs of the quadrature decoder module.<br>0b - Disabled<br>1b - Enabled                                                                                                      |
| 13<br>QDN           | Quadrature Decoder Negative Signal<br>Selects whether a negative or positive Quadrature Decoder signal is generated.<br>0b - Generates a positive quadrature decoder signal<br>1b - Generates a negative quadrature decoder signal |
| 12-8<br>TEST_PERIOD | TEST_PERIOD<br>Period of quadrature phase in IPBus clock cycles                                                                                                                                                                    |
| 7-0<br>TEST_COUNT   | TEST_COUNT<br>The number of quadrature advances to generate                                                                                                                                                                        |

### 32.6.1.40 Upper VERID (UVERID)

#### Offset

| Register | Offset |
|----------|--------|
| UVERID   | 50h    |

#### Function

Version ID Upper part

#### Diagram



#### Fields

| Field  | Function                                   |
|--------|--------------------------------------------|
| 15-0   | UVERID                                     |
| UVERID | Upper (most significant) half of the VERID |

### 32.6.1.41 Lower VERID (LVERID)

#### Offset

| Register | Offset |
|----------|--------|
| LVERID   | 52h    |

#### Function

Version ID Lower part

**Diagram****Fields**

| Field  | Function                                   |
|--------|--------------------------------------------|
| 15-0   | LVERID                                     |
| LVERID | Lower (most significant) half of the VERID |

# Chapter 33

## Frequency Measurement (FREQME)

### 33.1 Chip-specific FREQME information

Table 177. Reference links to related information

| Topic                | Related module | Reference                                     |
|----------------------|----------------|-----------------------------------------------|
| Full description     | FREQME         | <a href="#">FREQME</a>                        |
| System memory map    |                | <a href="#">Memory map</a>                    |
| Clocking             |                | <a href="#">Clock distribution</a>            |
| Power Management     |                | <a href="#">Power Management</a>              |
| Signal multiplexing  | Port control   | <a href="#">Signal multiplexing</a>           |
| Peripheral Input Mux | INPUTMUX       | <a href="#">Peripheral Input multiplexing</a> |

#### 33.1.1 Module instances

This device has one instance of the Frequency Measurement module.

#### 33.1.2 Input clock sources

Following are the input clocks for frequency measurement circuit:

- 0 Reserved
- 1 clk\_in
- 2 FRO\_OSC\_12M
- 3 fro\_hf\_div
- 4 Reserved
- 5 clk\_16k[1]
- 6 SLOW\_CLK
- 7 FREQME\_CLK\_IN0
- 8 FREQME\_CLK\_IN1
- 9 AOI0\_OUT0
- 10 AOI0\_OUT1
- 11 PWM0\_SM0\_MUX\_TRIG0
- 12 PWM0\_SM0\_MUX\_TRIG1
- 13 PWM0\_SM1\_MUX\_TRIG0
- 14 PWM0\_SM1\_MUX\_TRIG1
- 15 PWM0\_SM2\_MUX\_TRIG0
- 16 PWM0\_SM2\_MUX\_TRIG1
- 17 Reserved
- 18 Reserved

For details, see the FREQMEAS\_REF and FREQMEAS\_TAR registers in [Peripheral Input multiplexing](#) chapter.

## 33.2 Overview

FREQME accurately measures the frequency of an on- or off-chip target clock signal using a selectable on-chip reference clock. For example, it can accurately determine the frequency of a low-power oscillator that varies depending on process and temperature.

### 33.2.1 Block diagram



Figure 152. Block diagram

See the chip-specific FREQME information for the target and reference clock selection options.

### 33.2.2 Features

- High-accuracy Frequency Measurement mode for on- and off-chip clocks
- Pulse Width Measurement (PWM) mode
- Reference and target clock inputs selectable from among various chip-specific options
- Optional measurement complete interrupt
- Result out-of-range detection with optional interrupt

## 33.3 Functional description

The following sections describe FREQME functional details.

### 33.3.1 Frequency Measurement mode

In Frequency Measurement mode ([CTL\\_W\[PULSE\\_MODE\]](#) = 0), FREQME counts the number of target clock cycles that occur during a specified number of cycles from a reference clock that has a known frequency. You can then calculate the target clock frequency based on the frequency of the reference clock, the number of reference clock cycles, and the number of target clock cycles (see [Equation 1](#)).

The frequency measurement circuit is based on two 31-bit counters—one clocked by the selected reference clock and one by the selected target clock. You can only read the target clock counter. FREQME synchronizes the clocks at the start and end of each count sequence during preparation for the next count sequence. A count sequence consists of incrementing the target clock counter for each target clock pulse that occurs during the time defined by  $2^{CTRL\_W[REF\_SCALE]}$  periods of the reference clock.

After selecting reference and target clocks, you initiate a measurement cycle by writing 1 to [CTRL\\_W\[MEASURE\\_IN\\_PROGRESS\]](#). You can then poll this same field, which automatically transitions to 0 when the measurement operation completes. Alternatively, the completion of the measurement operation can generate an interrupt.

The measurement cycle terminates when the reference counter equals the value [2CTRLSTAT\[REFSCALE\]](#). If [CTRLSTAT\[REFSCALE\]](#) = 0, the reference counter counts to one and stops. You can use this feature to measure the frequency of a fast target clock using a slow reference clock such as the 32 kHz clock without taking much time for the measurement to complete. The penalty is reduced accuracy in the measurement.

When the counting operation completes, the state of the target counter is loaded into [CTRL\\_R\[RESULT\]](#), and the [CTRL\\_W\[MEASURE\\_IN\\_PROGRESS\]](#) field is 0. You can then read the value and calculate the target frequency as follows, with the frequencies given in MHz.

$$F_{\text{target}} = (\text{CTRL\_R}[\text{RESULT}] - 2) \times F_{\text{reference}} \div 2^{\text{CTRLSTAT}[\text{REFSCALE}]}$$

Equation 1. Calculating the target clock frequency

### 33.3.1.1 Accuracy

The Frequency Measurement mode can measure the frequency of any on-chip (or off-chip) clock (referred to as the target clock) with a high degree of accuracy by using an on-chip clock of known frequency as a reference clock.

Uncertainty in the reference clock (for example a  $\pm 1\%$  accuracy of the clock) adds to the measurement error of the target clock. In general, though, this additional error is less than the uncertainty of the reference clock.

### 33.3.2 Pulse Measurement mode

When you write 1 to [CTRL\\_W\[PULSE\\_MODE\]](#) and write 1 to [CTRL\\_W\[MEASURE\\_IN\\_PROGRESS\]](#) to start a measurement cycle, FREQME counts target clock pulses while the reference clock is in a specific state (high or low), selected by writing to [CTRL\\_W\[PULSE\\_POL\]](#). See the description of these fields for more details.

### 33.3.3 Clocking

The clock inputs are as follows:

- Reference clock (REF\_CLK\_IN). This clock has a known frequency.
- Target clock (TARGET\_CLK\_IN). This clock frequency can be calculated based on the reference clock.

**NOTE**

These clocks can be all synchronous.

See the chip-specific FREQME information for the target and reference clock selection options.

### 33.3.4 Interrupts

The following interrupts can optionally be generated at the completion of a frequency measurement cycle.

Table 178. Interrupts

| Condition                                             | Interrupt enable field                      | Interrupt status field                        |
|-------------------------------------------------------|---------------------------------------------|-----------------------------------------------|
| Result is ready to read                               | <a href="#">CTRL_W[RESULT_READY_INT_EN]</a> | <a href="#">CTRLSTAT[RESULT_READY_INT_EN]</a> |
| Result is greater than <a href="#">MAX[MAX_VALUE]</a> | <a href="#">CTRL_W[GT_MAX_INT_EN]</a>       | <a href="#">CTRLSTAT[GT_MAX_INT_EN]</a>       |
| Result is less than <a href="#">MIN[MIN_VALUE]</a>    | <a href="#">CTRL_W[LT_MIN_INT_EN]</a>       | <a href="#">CTRLSTAT[LT_MIN_INT_EN]</a>       |

## 33.4 External signals

Table 179. External signals

| Signal        | Description                                                              | Direction |
|---------------|--------------------------------------------------------------------------|-----------|
| REF_CLK_IN    | Reference clock. On-chip clock with known frequency chosen as reference. | Input     |
| TARGET_CLK_IN | Target clock. On- or off-chip clock to be measured by FREQME.            | Input     |

### 33.5 Initialization

Initialize FREQME by performing the following steps:

1. Enable the clock that drives FREQME in the chip-level clock control register. This step enables the register interface and the peripheral function clock.
2. Clear the FREQME peripheral reset in the chip-level reset control register.
3. If measuring an external clock, use the Input/Output pin configuration registers to connect the FREQME target clock input (TARGET\_CLK\_IN) to an external pin.
4. Ensure that the reference and target clocks are enabled.
5. Select the reference and target clocks.

### 33.6 Memory map and register definition

This section includes the FREQME memory map and detailed descriptions of all registers.

#### 33.6.1 FREQME register descriptions

##### 33.6.1.1 FREQME memory map

FREQME0 base address: 4000\_9000h

| Offset | Register                         | Width<br>(In bits) | Access | Reset value |
|--------|----------------------------------|--------------------|--------|-------------|
| 0h     | Control (in Read mode) (CTRL_R)  | 32                 | R      | 0000_0000h  |
| 0h     | Control (in Write mode) (CTRL_W) | 32                 | W      | 0000_0000h  |
| 4h     | Control Status (CTRLSTAT)        | 32                 | RW     | 0000_0000h  |
| 8h     | Minimum (MIN)                    | 32                 | RW     | 0000_0000h  |
| Ch     | Maximum (MAX)                    | 32                 | RW     | 7FFF_FFFFh  |

##### 33.6.1.2 Control (in Read mode) (CTRL\_R)

###### Offset

| Register | Offset |
|----------|--------|
| CTRL_R   | 0h     |

###### Function

Contains different fields depending on whether you are performing a read or a write. Reading this register provides the measurement results and the status of the measurement cycle.

**Diagram**

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

**Fields**

| Field                     | Function                                                                                                                                                                                                                                                                                                                                                                       |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>MEASURE_IN_PROGRESS | Measurement In Progress<br><br>Indicates whether measurement is in progress or complete. If complete, you can read the result from <b>RESULT</b> .<br><br>0b - Complete<br>1b - In progress                                                                                                                                                                                    |
| 30-0<br>RESULT            | Indicates the measurement result—either the target clock counter value (for Frequency Measurement mode) or pulse width measurement (for Pulse Width Measurement mode). This field is valid only when <b>MEASURE_IN_PROGRESS</b> = 0,<br><br>In Continuous mode ( <b>CTRL_W[CONTINUOUS_MODE_EN]</b> = 1), the value is the result from the most-recently completed measurement. |

**33.6.1.3 Control (in Write mode) (CTRL\_W)****Offset**

| Register | Offset |
|----------|--------|
| CTRL_W   | 0h     |

**Function**

Writes to this register control and configure the measurement cycle.

**Diagram**

| Bits  | 31             | 30             | 29             | 28             | 27 | 26             | 25             | 24 | 23 | 22 | 21 | 20 | 19        | 18 | 17 | 16 |
|-------|----------------|----------------|----------------|----------------|----|----------------|----------------|----|----|----|----|----|-----------|----|----|----|
| R     |                |                |                |                |    |                |                |    |    |    |    |    |           |    |    |    |
| W     | MEAS<br>URE... | CONTI<br>NU... |                |                |    |                |                |    | 0  |    |    |    |           |    |    |    |
| Reset | 0              | 0              | 0              | 0              | 0  | 0              | 0              | 0  | 0  | 0  | 0  | 0  | 0         | 0  | 0  | 0  |
| Bits  | 15             | 14             | 13             | 12             | 11 | 10             | 9              | 8  | 7  | 6  | 5  | 4  | 3         | 2  | 1  | 0  |
| R     |                |                |                |                |    |                |                |    |    |    |    |    |           |    |    |    |
| W     | 0              | RESU<br>LT_... | GT_M<br>AX_... | LT_MI<br>N_... | 0  | PULS<br>E_P... | PULS<br>E_M... |    | 0  |    |    |    | REF_SCALE |    |    |    |
| Reset | 0              | 0              | 0              | 0              | 0  | 0              | 0              | 0  | 0  | 0  | 0  | 0  | 0         | 0  | 0  | 0  |

**Fields**

| Field                            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br><b>MEASURE_IN_PROGRESS</b> | <p>Measurement In Progress</p> <p>Initiates a frequency measurement cycle or terminates a measurement cycle that is in progress.</p> <p>Writing 1 to this field initiates a frequency or pulse width measurement process. Hardware automatically writes 0 to the MEASURE_IN_PROGRESS field when the measurement cycle completes. If there is an active measurement in progress, a new measurement starts.</p> <p>Writing 0 to this field forces the termination of any measurement cycle currently in progress and resets <a href="#">CTRL_R[RESULT]</a> or just resets <a href="#">CTRL_R[RESULT]</a> if idle.</p> <p>0b - Terminates measurement</p> <p>1b - Initiates measurement</p> |
| 30<br><b>CONTINUOUS_MODE_EN</b>  | <p>Continuous Mode Enable</p> <p>When you write 1 to both <a href="#">MEASURE_IN_PROGRESS</a> and this field, measurement is performed continuously. The result for the most-recently completed measurement is available in <a href="#">CTRL_R[RESULT]</a>.</p> <p>When the result is out of range (that is, <a href="#">CTRLSTAT[GT_MAX_STAT]</a> = 1 or <a href="#">CTRLSTAT[LT_MIN_STAT]</a> = 1), this field automatically transitions to 0 and the continuous measurement is suspended. After clearing both status bits, you must write 1 to both MEASURE_IN_PROGRESS and this field restart measurement in continuous mode.</p> <p>0b - Disable</p> <p>1b - Enable</p>             |
| 29-15<br>—                       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 14<br><b>RESULT_READY_INT_EN</b> | <p>Result Ready Interrupt Enable</p> <p>Generates interrupt when a measurement completes and the result is ready (<a href="#">CTRLSTAT[RESULT_READY_STAT]</a> = 1).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      | 0b - Disable<br>1b - Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 13<br>GT_MAX_INT_EN  | Greater Than Maximum Interrupt Enable<br>Generates an interrupt when the result is greater than <a href="#">MAX[MAX_VALUE]</a> ( <a href="#">CTRLSTAT[GT_MAX_STAT]</a> = 1).<br>0b - Disable<br>1b - Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 12<br>LT_MIN_INT_E_N | Less Than Minimum Interrupt Enable<br>Generates an interrupt when the result is less than <a href="#">MIN[MIN_VALUE]</a> ( <a href="#">CTRLSTAT[LT_MIN_STAT]</a> = 1).<br>0b - Disable<br>1b - Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 11-10<br>—           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 9<br>PULSE_POL       | Pulse Polarity<br>Specifies whether a pulse width (high period or low period) of the reference clock is measured in the Pulse Width Measurement mode.<br><br><b>NOTE</b><br>PULSE_POL is valid only in the Pulse Width Measurement mode.<br><br><ul style="list-style-type: none"> <li>• A high period measurement is triggered by the rising edge on the reference clock input.</li> <li>• A low period measurement is triggered by the falling edge on the reference clock input.</li> </ul> 0b - High period<br>1b - Low period                                                                                                                                                                                                                                                                                                         |
| 8<br>PULSE_MODE      | Pulse Width Measurement Mode Select<br>Selects the measurement mode—either Frequency Measurement mode or Pulse Width Measurement mode.<br><br>In Frequency Measurement mode, measurement begins at the rising edge of the selected reference clock and continues until a count of <a href="#">2REF_SCALE</a> reference clock pulses is reached.<br><br>In Pulse Width Measurement mode, the counter starts incrementing when the selected trigger edge (rising edge for high period measurement or falling edge for low period) occurs, and stops at the next edge (falling edge for a high period measurement or rising edge for a low period measurement). Select high or low period measurement by writing the desired value to <a href="#">PULSE_POL</a> .<br><br>0b - Frequency Measurement mode<br>1b - Pulse Width Measurement mode |
| 7-5                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                                                                                                     |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —                |                                                                                                                                                                                                                                                                                                              |
| 4-0<br>REF_SCALE | Reference Clock Scaling Factor<br><br>Specifies the reference clock scaling factor in Frequency Measurement mode. The reference count cycle is $2^{\text{REF\_SCALE}}$ . A higher number provides better accuracy but consumes more processing time. This field is valid only in Frequency Measurement mode. |

### 33.6.1.4 Control Status (CTRLSTAT)

#### Offset

| Register | Offset |
|----------|--------|
| CTRLSTAT | 4h     |

#### Function

Contains the current CTRL\_W register configuration fields.

#### Diagram

| Bits  | 31             | 30             | 29            | 28            | 27            | 26             | 25             | 24 | 23 | 22 | 21 | 20 | 19        | 18 | 17 | 16 |
|-------|----------------|----------------|---------------|---------------|---------------|----------------|----------------|----|----|----|----|----|-----------|----|----|----|
| R     | MEAS<br>URE... | CONTI<br>NU... |               | 0             | RESU<br>LT... | GT_M<br>AX...  | LT_MI<br>N...  |    |    |    |    |    | 0         |    |    |    |
| W     |                |                |               |               | W1C           | W1C            | W1C            |    |    |    |    |    |           |    |    |    |
| Reset | 0              | 0              | 0             | 0             | 0             | 0              | 0              | 0  | 0  | 0  | 0  | 0  | 0         | 0  | 0  | 0  |
| Bits  | 15             | 14             | 13            | 12            | 11            | 10             | 9              | 8  | 7  | 6  | 5  | 4  | 3         | 2  | 1  | 0  |
| R     | 0              | RESU<br>LT...  | GT_M<br>AX... | LT_MI<br>N... | 0             | PULS<br>E_P... | PULS<br>E_M... |    | 0  |    |    |    | REF_SCALE |    |    |    |
| W     |                |                |               |               |               |                |                |    |    |    |    |    |           |    |    |    |
| Reset | 0              | 0              | 0             | 0             | 0             | 0              | 0              | 0  | 0  | 0  | 0  | 0  | 0         | 0  | 0  | 0  |

#### Fields

| Field                     | Function                                                                                                                                   |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>MEASURE_IN_PROGRESS | Measurement in Progress Status<br><br>Indicates the current CTRL_W[MEASURE_IN_PROGRESS] value.<br>0b - Not in progress<br>1b - In progress |
| 30                        | Continuous Mode Enable Status                                                                                                              |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                      | Function                                                                                                                                                                                                                                                                                              |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CONTINUOUS_MODE_EN         | Indicates the current <a href="#">CTRL_W[CONTINUOUS_MODE_EN]</a> value.<br>0b - Disabled<br>1b - Enabled                                                                                                                                                                                              |
| 29-27<br>—                 | Reserved                                                                                                                                                                                                                                                                                              |
| 26<br>RESULT_READ_Y_STAT   | Result Ready Status<br>Indicates that a measurement is complete and <a href="#">CTRL_R[RESULT]</a> is ready to read. Write 1 to this field to clear.<br>0b - Not complete<br>1b - Complete                                                                                                            |
| 25<br>GT_MAX_STAT          | Greater Than Maximum Result Status<br>Indicates that a measurement is complete and the result is greater than the maximum expected value ( <a href="#">CTRL_R[RESULT] &gt; MAX[MAX_VALUE]</a> ). Write 1 to this field to clear.<br>0b - Less than MAX[MAX_VALUE]<br>1b - Greater than MAX[MAX_VALUE] |
| 24<br>LT_MIN_STAT          | Less Than Minimum Results Status<br>Indicates that a measurement is complete and the result is less than the minimum expected value ( <a href="#">CTRL_R[RESULT] &lt; MIN[MIN_VALUE]</a> ). Write 1 to this field to clear.<br>0b - Greater than MIN[MIN_VALUE]<br>1b - Less than MIN[MIN_VALUE]      |
| 23-15<br>—                 | Reserved                                                                                                                                                                                                                                                                                              |
| 14<br>RESULT_READ_Y_INT_EN | Result Ready Interrupt Enable<br>Indicates the current <a href="#">CTRL_W[RESULT_READY_INT_EN]</a> value.<br>0b - Disabled<br>1b - Enabled                                                                                                                                                            |
| 13<br>GT_MAX_INT_EN        | Greater Than Maximum Interrupt Enable<br>Indicates the current <a href="#">CTRL_W[GT_MAX_INT_EN]</a> value.<br>0b - Disabled<br>1b - Enabled                                                                                                                                                          |
| 12                         | Less Than Minimum Interrupt Enable<br>Indicates the current <a href="#">CTRL_W[LT_MIN_INT_EN]</a> value.                                                                                                                                                                                              |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field             | Function                                                                                                                                              |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| LT_MIN_INT_E<br>N | 0b - Disabled<br>1b - Enabled                                                                                                                         |
| 11-10<br>—        | Reserved                                                                                                                                              |
| 9<br>PULSE_POL    | Pulse Polarity<br>Indicates the current <a href="#">CTRL_W[PULSE_POL]</a> value.<br>0b - High period<br>1b - Low period                               |
| 8<br>PULSE_MODE   | Pulse Mode<br>Indicates the current <a href="#">CTRL_W[PULSE_MODE]</a> value.<br>0b - Frequency Measurement mode<br>1b - Pulse Width Measurement mode |
| 7-5<br>—          | Reserved                                                                                                                                              |
| 4-0<br>REF_SCALE  | Reference Scale<br>Indicates the current <a href="#">CTRL_W[REF_SCALE]</a> value.                                                                     |

### 33.6.1.5 Minimum (MIN)

#### Offset

| Register | Offset |
|----------|--------|
| MIN      | 8h     |

#### Function

Specifies the minimum expected value for the measurement result.

**Diagram****Fields**

| Field             | Function                                                            |
|-------------------|---------------------------------------------------------------------|
| 31                | Reserved                                                            |
| —                 |                                                                     |
| 30-0<br>MIN_VALUE | Minimum Value<br>Minimum expected value for the measurement result. |

**33.6.1.6 Maximum (MAX)****Offset**

| Register | Offset |
|----------|--------|
| MAX      | Ch     |

**Function**

Specifies the maximum expected value for the measurement result.

**Diagram**

**Fields**

| Field     | Function                                           |
|-----------|----------------------------------------------------|
| 31        | Reserved                                           |
| —         |                                                    |
| 30-0      | Maximum Value                                      |
| MAX_VALUE | Maximum expected value for the measurement result. |

# Chapter 34

## Low-Power Timer (LPTMR)

### 34.1 Chip-specific LPTMR information

Table 180. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | LPTMR          | <a href="#">LPTMR</a>               |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 34.1.1 Module instances

This device has one instance of the LPTMR module, LPTMR0.

#### 34.1.2 LPTMR clocks

The prescaler and glitch filter of the LPTMR module (the module functional clock) can be clocked from one of four sources determined by LPTMRx\_PSR[PCS]. The following table shows the clock assignments for this field.

**NOTE**

The chosen clock must remain enabled if the LPTMR is to continue operating in all required low-power modes.

The LPTMR allows the maximum clock frequency of 25 MHz.

Table 181. LPTMRn prescaler/glitch filter clocking options

| LPTMRn_PSR[PCS] | Prescaler/glitch filter clock number | Chip clock                                                                                                                                                                                                     |
|-----------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00              | 0                                    | Reserved.                                                                                                                                                                                                      |
| 01              | 1                                    | FRO_16K                                                                                                                                                                                                        |
| 10              | 2                                    | Reserved                                                                                                                                                                                                       |
| 11              | 3                                    | Combination of clocks configured in MRCC_LPTMR0_CLKSEL[MUX] field in SYSCON module. The Clock frequency must be less than 25 MHz to be used as a clock for the Low Power Timers. See <a href="#">Figure 60</a> |

#### 34.1.3 LPTMR pulse counter input options

LPTMRn\_CSR[TPS] configures the input source used in pulse counter mode. The following table shows the input assignments for this field.

Table 182. LPTMR<sub>n</sub> (n=0,1) pulse counter input options

| LPTMR <sub>n</sub> _CSR[TPS] | Pulse counter input number | Chip input               |
|------------------------------|----------------------------|--------------------------|
| 00                           | 0                          | CMP0_OUT                 |
| 01                           | 1                          | CMP1_OUT                 |
| 10                           | 2                          | LPTMR <sub>n</sub> _Alt2 |
| 11                           | 3                          | LPTMR <sub>n</sub> _Alt3 |

## 34.2 Overview

You can configure LPTMR to operate as a time counter with an optional prescaler, or as a pulse counter with an optional glitch filter, across all power modes, including low-power modes. It is reset only on VSYS Cold Reset, allowing it to be used as a time-of-day counter.

### 34.2.1 Block diagram



Figure 153. Block diagram

### 34.2.2 Features

- 32-bit time counter or pulse counter with compare:
  - Optional interrupt that can generate an asynchronous wake-up from any low-power mode
  - Hardware trigger output
  - Counter that supports a free-running mode or reset on compare
- Configurable clock source for prescaler and glitch filter
- Configurable input source for pulse counter (rising-edge or falling-edge)

## 34.3 Functional description

### 34.3.1 Low-power modes

In low-power modes, LPTMR continues to operate normally. You can configure LPTMR to exit a low-power mode by generating either an interrupt or a DMA request.

### 34.3.2 Clocks

The LPTMR prescaler and glitch filter can be clocked by one of the clocks that you configure by using [PSR\[PCS\]](#). You must enable the clock source before you enable LPTMR.

In Pulse Counter mode, with the glitch filter bypassed, the selected input source directly clocks [Counter \(CNR\)](#), and no other clock source is required. To minimize power in this case, configure the glitch filter clock source for a clock that is disabled.

#### NOTE

- You may need to configure the clock source that you select in PSR[PCS] for it to remain enabled in low-power modes. Otherwise, LPTMR does not operate in low-power modes.
- The clock source or pulse input source selected for LPTMR must not exceed the maximum frequency of  $f_{LPTMR}$  defined in the chip data sheet.

### 34.3.3 Reset

LPTMR is reset only on VSYS Cold Reset. When configuring LPTMR registers, you must initially write to [Control Status \(CSR\)](#) with LPTMR disabled, before configuring [Prescaler and Glitch Filter \(PSR\)](#) and [Compare \(CMR\)](#). Then, you must write 1 to [CSR\[TEN\]](#) as the last step in the initialization. Doing so ensures that LPTMR is configured correctly and the LPTMR counter is reset to zero following a VSYS Cold Reset.

### 34.3.4 Prescaler and glitch filter

The LPTMR prescaler and glitch filter share the same logic, which operates as a prescaler in Time Counter mode and as a glitch filter in Pulse Counter mode.

#### NOTE

You must not alter the prescaler and glitch filter configuration when LPTMR is enabled.

#### 34.3.4.1 Prescaler enabled

In Time Counter mode, when the prescaler is enabled, the output of the prescaler directly clocks [Counter \(CNR\)](#). When LPTMR is enabled, CNR increments every  $2^1$  to  $2^{16}$  prescaler clock cycles. After LPTMR is enabled, the first increment of CNR takes an additional one or two prescaler clock cycles because of the synchronization logic.

#### 34.3.4.2 Prescaler bypassed

In Time Counter mode, when the prescaler is bypassed, the selected prescaler clock increments [Counter \(CNR\)](#) on every clock cycle. When LPTMR is enabled, the first increment takes an additional one or two prescaler clock cycles because of the synchronization logic.

#### 34.3.4.3 Glitch filter enabled

In Pulse Counter mode, when the glitch filter is enabled, the output of the glitch filter directly clocks [Counter \(CNR\)](#). When LPTMR is first enabled, the output of the glitch filter is asserted, that is, logic 1 for active-high and logic 0 for active-low. The following table shows the change in glitch filter output with the selected input source.

Table 183. Glitch filter output with the selected input source

| If                                                                                                                   | Then                                     |
|----------------------------------------------------------------------------------------------------------------------|------------------------------------------|
| The selected input source remains deasserted for at least $2^1$ to $2^{15}$ consecutive prescaler clock rising edges | The glitch filter output also deasserts. |
| The selected input source remains asserted for at least $2^1$ to $2^{15}$ consecutive prescaler clock rising edges   | The glitch filter output also asserts.   |

---

**NOTE**

The input is sampled only on the rising clock edge.

The value of CNR increments each time the glitch filter output asserts. In Pulse Counter mode, the maximum rate at which CNR can increment is once every  $2^2$  to  $2^{16}$  glitch filter clock edges. When first enabled, the glitch filter waits for an additional one or two glitch filter clock edges because of the synchronization logic.

#### 34.3.4.4 Glitch filter bypassed

In Pulse Counter mode, when the glitch filter is bypassed, the selected input source increments the value of [Counter \(CNR\)](#) every time it asserts. Before LPTMR is first enabled, the selected input source is forced to be asserted. This prevents CNR from incrementing if the selected input source is already asserted when LPTMR is first enabled.

#### 34.3.5 Counter

The value of [Counter \(CNR\)](#) increments by 1 on every:

- Prescaler clock in Time Counter mode, with prescaler bypassed.
- Prescaler output in Time Counter mode, with prescaler enabled.
- Input source assertion in Pulse Counter mode, with glitch filter bypassed.
- Glitch filter output in Pulse Counter mode, with glitch filter enabled.

CNR is reset when LPTMR is disabled or if the counter register overflows. If [CSR\[TCF\]](#) = 0, then CNR is also reset whenever [CSR\[TCF\]](#) = 1.

When the core is halted in Debug mode:

- CNR continues incrementing if configured for Pulse Counter mode.
- CNR stops incrementing if configured for Time Counter mode.

You cannot initialize CNR but can read it at any time. On each read of CNR, you must first write a value to it. This synchronizes and registers the current value of CNR into a temporary register. The contents of the temporary register are returned on each read of CNR.

When reading CNR, the bus clock must be at least two times faster than the rate at which the LPTMR counter is incrementing; otherwise, incorrect data may be returned.

#### 34.3.6 Compare

After the next [Counter \(CNR\)](#) increment (when its value is equal to that of [Compare \(CMR\)](#)), the following events occur:

- [CSR\[TCF\]](#) is read as 1b.
- LPTMR generates an interrupt if [CSR\[TIE\]](#) is 1 as well.
- LPTMR generates a hardware trigger.
- LPTMR writes 0 to CNR if [CSR\[TFC\]](#) is 0.

When LPTMR is enabled, you can modify the value of CMR only when CSR[TCF] is 1. When updating CMR, you must write to it and clear CSR[TCF] before the LPTMR counter increments past the new LPTMR compare value.

---

**NOTE**

When LPTMR is enabled in Time Counter mode, the first increment takes an additional one or two clock cycles because of the synchronization logic. This results in the first compare (and therefore interrupt and hardware trigger) occurring slightly later. A faster prescaler clock or larger prescaler value minimizes this impact.

### 34.3.7 Interrupt

LPTMR generates an interrupt whenever [CSR\[TIE\]](#) and [CSR\[TCF\]](#) are 1. CSR[TCF] is cleared by disabling LPTMR or writing a logic 1 to it.

You can modify the value of CSR[TIE] and write 1 to CSR[TCF] when LPTMR is enabled.

LPTMR generates an interrupt asynchronously to the system clock. The interrupt can be used to generate a wake-up from any low-power mode, provided LPTMR is enabled as a wake-up source.

### 34.3.8 Hardware trigger

The LPTMR hardware trigger asserts at the same time [CSR\[TCF\]](#) is set and can be used to trigger hardware events in other peripherals without your intervention. The hardware trigger is always enabled.

Table 184. Hardware trigger

| When                                                                                       | Then                                                                                                                           |
|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| <a href="#">CMR[COMPARE]</a> and <a href="#">CSR[TCF]</a> are 0                            | The LPTMR hardware trigger asserts on the first compare and does not deassert.                                                 |
| <a href="#">CMR[COMPARE]</a> is set to a nonzero value, or if <a href="#">CSR[TFC]</a> = 1 | The LPTMR hardware trigger asserts on each compare and deasserts on the following increment of <a href="#">Counter (CNR)</a> . |

## 34.4 External signals

Table 185. External signals

| Signal                     | Description                                                                                         |                                                                                                                                                                                                                                                               | Direction |
|----------------------------|-----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|
| <a href="#">LPTMR_ALTn</a> | Pulse Counter Input<br><br>LPTMR can select one of the input pins to be used in Pulse Counter mode. |                                                                                                                                                                                                                                                               | Input     |
|                            | State meaning                                                                                       | Assertion—if configured for Pulse Counter mode with an active-high input, assertion causes <a href="#">Counter (CNR)</a> to increment.<br><br>Deassertion—if configured for Pulse Counter mode with an active-low input, deassertion causes CNR to increment. |           |
|                            | Timing                                                                                              | Assertion or deassertion may occur at any time; input may assert asynchronously to the bus clock.                                                                                                                                                             |           |

## 34.5 Initialization

Perform the following procedure to initialize LPTMR:

1. Configure [Control Status \(CSR\)](#) for the selected mode and pin configuration, when [CSR\[TEN\]](#) is 0. This resets the counter and clears the flag.
2. Configure [Prescaler and Glitch Filter \(PSR\)](#) with the selected clock source and prescaler or glitch filter configuration.
3. Configure [Compare \(CMR\)](#) with the selected compare point.
4. Write 1 to [CSR\[TEN\]](#) to enable LPTMR.

## 34.6 Application information

### 34.6.1 Application 1: Generate an interrupt every 100 ms using 32.768 kHz clock source

1. Disable LPTMR by writing 0 to [CSR\[TEN\]](#).
2. Select a 32.768 kHz clock source by configuring [PSR\[PCS\]](#).
3. Bypass the prescaler and glitch filter by writing 1 to [PSR\[PBYP\]](#).
4. Assert an interrupt every 3277 cycles by configuring [CMR\[COMPARE\]](#) = 0CCCh.
5. Enable LPTMR by writing 1 to [CSR\[TEN\]](#).
6. Enable the LPTMR interrupt by writing 1 to [CSR\[TIE\]](#).

**NOTE**

This is just an example. See the chip-specific LPTMR information for the clocks supported on a given chip.

### 34.6.2 Application 2: Generate an interrupt once a minute using 32.768 kHz clock source

1. Disable LPTMR by writing 0 to [CSR\[TEN\]](#).
2. Select a 32.768 kHz clock source by configuring [PSR\[PCS\]](#).
3. Select the prescaler to divide the prescaler clock by 32768 to increment the counter once a second by configuring [PSR\[PRESCALE\]](#) = 0Eh.
4. Assert an interrupt every 60 seconds by configuring [CMR\[COMPARE\]](#) = 003Bh.
5. Enable LPTMR by writing 1 to [CSR\[TEN\]](#).
6. Enable the LPTMR interrupt by writing 1 to [CSR\[TIE\]](#).

**NOTE**

This is just an example. See the chip-specific LPTMR information for the clocks supported on a given chip.

## 34.7 Memory map and register definition

**NOTE**

The LPTMR registers are reset only on VSYS Cold Reset. See [Reset](#) for more information.

### 34.7.1 LPTMR register descriptions

#### 34.7.1.1 LPTMR memory map

LPTMR0 base address: 400A\_B000h

| Offset | Register                                          | Width<br>(In bits) | Access | Reset value |
|--------|---------------------------------------------------|--------------------|--------|-------------|
| 0h     | <a href="#">Control Status (CSR)</a>              | 32                 | RW     | 0000_0000h  |
| 4h     | <a href="#">Prescaler and Glitch Filter (PSR)</a> | 32                 | RW     | 0000_0000h  |
| 8h     | <a href="#">Compare (CMR)</a>                     | 32                 | RW     | 0000_0000h  |
| Ch     | <a href="#">Counter (CNR)</a>                     | 32                 | RW     | 0000_0000h  |

### 34.7.1.2 Control Status (CSR)

#### Offset

| Register | Offset |
|----------|--------|
| CSR      | 0h     |

#### Function

Controls various features of LPTMR.

#### Diagram



#### Fields

| Field     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-9<br>— | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 8<br>TDRE | <p>Timer DMA Request Enable</p> <p>Enables the timer DMA request. When TDRE is 1, the LPTMR DMA request is generated whenever <a href="#">CSR[TCF]</a> is also set. Then, CSR[TCF] is cleared after the DMA controller completes execution.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                           |
| 7<br>TCF  | <p>Timer Compare Flag</p> <p>Compares the timer. TCF sets on the next <a href="#">Counter (CNR)</a> increment when LPTMR is enabled and <a href="#">Counter (CNR)</a> equals <a href="#">Compare (CMR)</a>. TCF is cleared when LPTMR is disabled or a logic 1 is written to it.</p> <p><b>NOTE</b><br/>You must clear this flag before enabling the timer interrupt or DMA request.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | <p>When reading</p> <p>0b - CNR ≠ (CMR + 1)<br/>1b - CNR = (CMR + 1)</p> <p>When writing</p> <p>0b - No effect<br/>1b - Clear the flag</p>                                                                                                                                                                                                                                                                                                                                                          |
| 6<br>TIE   | <p>Timer Interrupt Enable</p> <p>Enables the timer interrupt. If TIE is 1, then LPTMR generates an interrupt if <a href="#">CSR[TCF]</a> is 1 as well.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                                                      |
| 5-4<br>TPS | <p>Timer Pin Select</p> <p>Configures the input source to be used in Pulse Counter mode. The input connections vary by chip. For details, see the chip configuration information about connections to these inputs.</p> <p>You must modify this field only when LPTMR is disabled.</p> <p>00b - Input 0<br/>01b - Input 1<br/>10b - Input 2<br/>11b - Input 3</p>                                                                                                                                   |
| 3<br>TPP   | <p>Timer Pin Polarity</p> <p>Configures the polarity of the input source in Pulse Counter mode. If TPP is 0, then the pulse counter input source is active-high, and <a href="#">Counter (CNR)</a> increments on the rising edge. If TPP is 1, then the pulse counter input source is active-low, and CNR increments on the falling edge.</p> <p>You must modify this field only when LPTMR is disabled.</p> <p>0b - Active-high<br/>1b - Active-low</p>                                            |
| 2<br>TFC   | <p>Timer Free-Running Counter</p> <p>Specifies when the counter resets. If TFC is 0, <a href="#">Counter (CNR)</a> resets on the count cycle following <a href="#">Counter (CNR)</a> becoming equal to <a href="#">Compare (CMR)</a>. If TFC is 1, CNR resets on overflow. In both cases, <a href="#">CSR[TCF]</a> sets to 1 on the cycle after CNR and CMR match.</p> <p>You must modify this field only when LPTMR is disabled.</p> <p>0b - Reset when TCF asserts<br/>1b - Reset on overflow</p> |
| 1          | <p>Timer Mode Select</p> <p>Configures the mode of LPTMR.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                             |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TMS      | You must modify this field only when LPTMR is disabled.<br>0b - Time Counter<br>1b - Pulse Counter                                                                                                                                                                                   |
| 0<br>TEN | Timer Enable<br>Enables the LPTMR timer. If TEN is 0, it resets the LPTMR internal logic, including <a href="#">CNR[COUNTER]</a> and <a href="#">CSR[TCF]</a> . If TEN is 1, LPTMR is enabled.<br>Do not alter CSR[5:1] when writing 1 to this field.<br>0b - Disable<br>1b - Enable |

### 34.7.1.3 Prescaler and Glitch Filter (PSR)

#### Offset

| Register | Offset |
|----------|--------|
| PSR      | 4h     |

#### Function

Configures features related to the prescaler and glitch filter.

#### Diagram



#### Fields

| Field | Function |
|-------|----------|
| 31-7  | Reserved |
| —     |          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6-3<br>PRESCALE | <p>Prescaler and Glitch Filter Value</p> <p>Configures the size of the prescaler in Time Counter mode and the width of the glitch filter in Pulse Counter mode. The width of the glitch filter can vary by one cycle because of the pulse counter input synchronization.</p> <p>You must modify this field only when LPTMR is disabled.</p> <ul style="list-style-type: none"> <li>0000b - Prescaler divides the prescaler clock by 2; glitch filter does not support this configuration</li> <li>0001b - Prescaler divides the prescaler clock by 4; glitch filter recognizes change on input pin after two rising clock edges</li> <li>0010b - Prescaler divides the prescaler clock by 8; glitch filter recognizes change on input pin after four rising clock edges</li> <li>0011b - Prescaler divides the prescaler clock by 16; glitch filter recognizes change on input pin after eight rising clock edges</li> <li>0100b - Prescaler divides the prescaler clock by 32; glitch filter recognizes change on input pin after 16 rising clock edges</li> <li>0101b - Prescaler divides the prescaler clock by 64; glitch filter recognizes change on input pin after 32 rising clock edges</li> <li>0110b - Prescaler divides the prescaler clock by 128; glitch filter recognizes change on input pin after 64 rising clock edges</li> <li>0111b - Prescaler divides the prescaler clock by 256; glitch filter recognizes change on input pin after 128 rising clock edges</li> <li>1000b - Prescaler divides the prescaler clock by 512; glitch filter recognizes change on input pin after 256 rising clock edges</li> <li>1001b - Prescaler divides the prescaler clock by 1024; glitch filter recognizes change on input pin after 512 rising clock edges</li> <li>1010b - Prescaler divides the prescaler clock by 2048; glitch filter recognizes change on input pin after 1024 rising clock edges</li> <li>1011b - Prescaler divides the prescaler clock by 4096; glitch filter recognizes change on input pin after 2048 rising clock edges</li> <li>1100b - Prescaler divides the prescaler clock by 8192; glitch filter recognizes change on input pin after 4096 rising clock edges</li> <li>1101b - Prescaler divides the prescaler clock by 16,384; glitch filter recognizes change on input pin after 8192 rising clock edges</li> <li>1110b - Prescaler divides the prescaler clock by 32,768; glitch filter recognizes change on input pin after 16,384 rising clock edges</li> <li>1111b - Prescaler divides the prescaler clock by 65,536; glitch filter recognizes change on input pin after 32,768 rising clock edges</li> </ul> |
| 2<br>PBYP       | <p>Prescaler and Glitch Filter Bypass</p> <p>Controls the clocking of <a href="#">Counter (CNR)</a>. If PBYP is 0, the output of the prescaler or glitch filter clocks CNR. If PBYP is 1, the selected prescaler clock in Time Counter mode, or else the selected input source in Pulse Counter mode, directly clocks CNR.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | <p>You must modify this field only when LPTMR is disabled.</p> <p>0b - Prescaler and glitch filter enable<br/>1b - Prescaler and glitch filter bypass</p>                                                                                                                                                                                                                                                                                                                                                                    |
| 1-0 PCS | <p>Prescaler and Glitch Filter Clock Select</p> <p>Selects the clock to be used by the LPTMR prescaler and glitch filter.</p> <p>In Time Counter mode, PCS selects the input clock to the prescaler.</p> <p>In Pulse Counter mode, PCS selects the input clock to the glitch filter.</p> <p>See the chip configuration details for information on connections to these inputs.</p> <p>You must modify this field only when LPTMR is disabled.</p> <p>00b - Clock 0<br/>01b - Clock 1<br/>10b - Clock 2<br/>11b - Clock 3</p> |

#### 34.7.1.4 Compare (CMR)

##### Offset

| Register | Offset |
|----------|--------|
| CMR      | 8h     |

##### Function

Configures the compare values to [Counter \(CNR\)](#) (see [Compare](#) for more information).

##### Diagram

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

## Fields

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>COMPARE | <p>Compare Value</p> <p>Configures the compare values to <a href="#">Counter (CNR)</a>.</p> <p>On the next CNR increment, if LPTMR is enabled and <a href="#">Counter (CNR)</a> equals <a href="#">Compare (CMR)</a>, then:</p> <ol style="list-style-type: none"> <li>1. LPTMR writes 1 to <a href="#">CSR[TCF]</a>.</li> <li>2. The hardware trigger asserts until the next time CNR increments.</li> </ol> <p>If CMR = 0, the hardware trigger remains asserted until LPTMR is disabled. If LPTMR is enabled, you must modify the value of CMR only if CSR[TCF] is 1.</p> |

### 34.7.1.5 Counter (CNR)

#### Offset

| Register | Offset |
|----------|--------|
| CNR      | Ch     |

#### Function

Specifies counter values (see [Counter](#) for more information).

#### Diagram



#### Fields

| Field           | Function                                                                                                                 |
|-----------------|--------------------------------------------------------------------------------------------------------------------------|
| 31-0<br>COUNTER | <p>Counter Value</p> <p>Contains the current value of the LPTMR counter at the time you last wrote to this register.</p> |

# Chapter 35

## USB Full Speed (FS) Device Controller

### 35.1 Chip-specific USBFS information

Table 186. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | USBFS          | <a href="#">USBFS</a>               |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 35.1.1 Module instances

This device has one instance of the USBFS module, USBFS0 and one USB FS PHY. Only Device mode is supported on this device. Any references to the host mode should be ignored.

### 35.2 Overview

USBFS comprises a Device-only subsystem that provides functionality for implementing a USB 2.0 Full-Speed compliant peripheral.

In this subsystem, the USB full-speed controller interfaces to a USB FS/LS transceiver and [Memory map and register definitions](#) also includes configuration controls for that transceiver.

In Device mode, the USBFS subsystem working with the SCG module can use the FIRC to generate a 48 MHz USB controller clock tuned using the incoming host USB data for crystal-less operation. [Memory map and register definitions](#) also include the registers necessary for configuration controls and status signals of the USB portion of this crystal-less operation.

#### 35.2.1 Block diagram



Figure 154. USB FS/LS subsystem overview

### 35.2.2 Features

- Includes a dual-role USB OTG-capable controller that supports Full-Speed (FS) device or FS/LS embedded host operation. The controller operates with DMA or FIFO data stream interfaces and supports up to 16 bidirectional endpoints. The module complies with the USB 2.0 specification.
- Supports a USB transceiver that includes a 1.5 kΩ pullup on the D+ line for Device mode functionality.
- Includes FIRC with clock recovery block to eliminate the need for a clock from a 48 MHz crystal. The USB frequency tuning feature is available only for USB device mode operation (see the SCG chapter in this Reference Manual for more information).
- A configurable connection allows any one of the LPUART transmit and receive pins to be connected to the Full Speed USB physical layer.
- Supports lane reversal feature to allow switching the roles of package USB0\_DM and USB0\_DP pins providing additional flexibility for PC board layout.

### 35.2.3 USB interface general overview

The USB is a cable bus that supports data exchange between a host computer and a wide range of simultaneously accessible peripherals. The bus allows peripherals to be attached, configured, used, and detached when the host and other peripherals operate. The attached peripherals share USB bandwidth through a host-scheduled, token-based protocol.

USB software provides a uniform system view for all application software, hiding implementation details to make application software more portable. It manages the dynamic attaching and detaching of peripherals.

There is only one host in any USB system. The USB interface to the host computer system is referred to as the host controller.

Any system may have multiple USB devices, such as human interface devices, speakers, printers, etc. USB devices present a standard USB interface regarding comprehension, response, and standard capability.

The host initiates transactions to specific peripherals, whereas the device responds to control transactions. The device sends and receives data to and from the host using a standard USB data format. USB 2.0 full-speed/low-speed peripherals operate at 12 Mbit/s or 1.5 Mbit/s.

See the USB 2.0 specification for more information.



Figure 155. Example USB 2.0 system configuration

### 35.2.4 References

The following publications are referenced in this document. For copies or updates to these specifications, see the USB Implementers Forum, Inc. website at <http://www.usb.org>.

- Universal Serial Bus Specification, Revision 2.0*, 2000, with amendments including those listed below

- Errata for “USB Revision 2.0 April 27, 2000” as of 12/7/2000
- Errata for “USB Revision 2.0 April 27, 2000” as of May 28, 2002
- Pullup / Pulldown Resistors (USB Engineering Change Notice)
- Suspend Current Limit Changes (USB Engineering Change Notice)
- Device Capacitance (USB Engineering Change Notice)
- USB 2.0 Connect Timing Update (USB Engineering Change Notice as of April 4, 2013)
- USB 2.0 VBUS Max Limit (USB Engineering Change Notice)
- On-The-Go and Embedded Host Supplement to the USB Revision 2.0 Specification, Revision 2.0 version 1.1a, July 27, 2012
- Maximum VBUS Voltage (USB OTGEH Engineering Change Notice)
- Universal Serial Bus Micro-USB Cables and Connectors Specification, Revision 1.01, 2007

### 35.3 Functional description

#### 35.3.1 On-chip transceiver required external components

USB system operation requires external components to ensure that you have met the driver output impedance, eye diagram, and VBUS cable fault tolerance requirements. DM and DP I/O pads must connect through series resistors (approximately  $33\ \Omega$  each) to the USB connector on the application printed circuit board (PCB). Additionally, signal quality optimizes when you mount these  $33\ \Omega$  resistors closer to the processor than the USB board-level connector. The USB transceiver includes the following:

- An internal  $1.5\ k\Omega$  pullup resistor on the USB\_DP line for the full-speed device ([CONTROL\[DPPULLUPNONOTG\]](#) controls).

The following diagram provides an overview of Device-only connections. See *Kinetis Peripheral Module Quick Reference (KQRUG)*, available on [www.nxp.com](http://www.nxp.com), for more information.



Figure 156. Typical Device-only block diagram (bus-powered with external regulator)

#### 35.3.2 Programmer interface

USBFS communicates with the processor core through status registers, control registers, and data structures in memory. This section discusses the major components of the programming model for USBFS.

### 35.3.2.1 Buffer descriptor table (BDT)

The device operation's function is to transfer a request in the memory image to and from the USB. USBFS implements a BDT to manage USB endpoint communications in system memory efficiently.

- The BDT resides on a 512-byte boundary in system memory and is pointed to by the BDT page registers.
- Every endpoint direction requires two 8-byte buffer descriptor (BD) entries.

Therefore, a system with 16 fully bidirectional endpoints requires 512 bytes of system memory to implement the BDT. The two BD entries allow for an EVEN BD and ODD BD entry for each endpoint direction, which enables the microprocessor to process one BD while USBFS is processing the other BD. Double buffering BDs allow USBFS to transfer data easily at the maximum throughput provided by USB.

You must manage buffers for USBFS by updating the BDT when needed. This allows USBFS to efficiently manage data transmission and reception while the microprocessor performs communication overhead processing and other function-dependent applications.

Because the buffers are shared between the microprocessor and USBFS, a simple semaphore mechanism distinguishes who is allowed to update the BDT and buffers in system memory. A semaphore (the OWN field) becomes 0 when the microprocessor owns the BD entry.

- When OWN = 0, the microprocessor is allowed read and write access to the BD entry and the buffer in system memory.
- When OWN = 1, USBFS owns the BD entry and the buffer in system memory. USBFS now has full read and write access, and the microprocessor must not modify the BD or its corresponding data buffer.

The BD also contains indirect address pointers where the actual buffer resides in system memory. The following diagram shows this indirect address mechanism.



Figure 157. Buffer descriptor table

### 35.3.2.2 Addressing BDT entries

An understanding of the addressing mechanism of BDT is useful when accessing endpoint data via USBFS or microprocessor:

- The BDT occupies up to 512 bytes of system memory.
- You can support 16 bidirectional endpoints with a full BDT of 512 bytes.
- 16 bytes are needed for each USB endpoint direction.
- Applications with fewer than 16 endpoints require less RAM to implement the BDT.
- The BDT page registers (BDT\_PAGE) point to the starting location of the BDT.
- You must locate the BDT on a 512-byte boundary in system memory.
- All enabled transit and receive endpoint BD entries are indexed into the BDT to allow easy access via USBFS or MCU core.

When you receive a USB token on an enabled endpoint, USBFS uses its integrated DMA controller to interrogate the BDT. USBFS reads the corresponding endpoint BD entry to determine whether it (USBFS) owns the BD and corresponding buffer in system memory.

To compute the entry point into the BDT, the BDT\_PAGE registers are concatenated with the current endpoint and the TX and ODD fields to form a 32-bit address. This following tables show this address mechanism:

**Table 187. BDT address calculation**

| 31:24       | 23:16       | 15:9             | 8:5      | 4  | 3   | 2:0 |
|-------------|-------------|------------------|----------|----|-----|-----|
| BDT_PAGE_03 | BDT_PAGE_02 | BDT_PAGE_01[7:1] | Endpoint | TX | ODD | 000 |

**Table 188. BDT address calculation fields**

| Field    | Description                                                                                                                  |
|----------|------------------------------------------------------------------------------------------------------------------------------|
| BDT_PAGE | BDT_PAGE registers in the control register block                                                                             |
| ENDPOINT | ENDPOINT field from the USB TOKEN                                                                                            |
| TX       | 1 for transmit transfers; 0 for receive transfers                                                                            |
| ODD      | It corresponds to the buffer currently in use; the buffers are used in a ping-pong fashion. Maintained within the USBFS SIE. |

### 35.3.2.3 Buffer descriptors (BDs)

A buffer descriptor provides endpoint buffer control information for USBFS and the processor. The BDs have different meanings, depending on whether USBFS or the processor reads the BD in memory.

The USBFS controller uses the data stored in the BDs to determine:

- Who owns the buffer in system memory
- Data0 or Data1 PID
- Whether to release ownership upon packet completion
- No address increment (FIFO mode)
- Whether data toggle synchronization is enabled
- How much data to transmit or receive
- Where the buffer resides in system memory

The processor uses the data stored in the BDs to determine:

- Who owns the buffer in system memory

- Data0 or Data1 PID
- The received TOKEN PID
- How much data was transmitted or received
- Where the buffer resides in system memory

The format for the BD is shown in the following table.

**Table 189. Buffer descriptor format**

| 31:26      25:16      15:8      7      6      5      4      3      2      1      0 |                 |      |     |         |                     |                     |                    |                          |   |   |
|------------------------------------------------------------------------------------|-----------------|------|-----|---------|---------------------|---------------------|--------------------|--------------------------|---|---|
| RSVD                                                                               | BC<br>(10 bits) | RSVD | OWN | DATA0/1 | KEEP/<br>TOK_PID[3] | NINC/<br>TOK_PID[2] | DTS/<br>TOK_PID[1] | BDT_STALL/<br>TOK_PID[0] | 0 | 0 |
| Buffer Address (32 bits)                                                           |                 |      |     |         |                     |                     |                    |                          |   |   |

**Table 190. Buffer descriptor fields**

| Field                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–26<br>RSVD            | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 25–16<br>BC              | Byte Count<br>Represents the 10-bit byte count. USBFS SIE changes this field upon completing a receive transfer with the byte count of the data received.                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15–8<br>RSVD             | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7<br>OWN                 | Determines whether the processor or USBFS currently owns the buffer. Except when KEEP = 1, the SIE hands ownership back to the processor after completing the token by writing 0 to this field.<br>This must always be the last byte of the BD that the processor updates when it initializes a BD.<br>0 The processor has access to the BD. USBFS ignores all other fields in the BD.<br>1 USBFS has access to the BD. When USBFS owns the BD, the processor must not modify any other fields in the BD.                                                                                                        |
| 6<br>DATA0/1             | Defines whether you transmit or receive a DATA0 field (DATA0/1=0) or a DATA1 (DATA0/1=1) field. It is unchanged by USBFS.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 5<br>KEEP/<br>TOK_PID[3] | Has two functions (KEEP or TOK_PID[3]): <ul style="list-style-type: none"> <li>• KEEP—When written by the processor, it serves as the KEEP bit. Typically, this bit is 1 with ISO endpoints feeding a FIFO. The microprocessor is not informed that a token has been processed. Transfer the data to or from the FIFO. When KEEP becomes 1, the NINC field usually becomes 1 to prevent address increment.</li> <li>0 Allows USBFS to release the BD when a token has been processed.</li> <li>1 This field is unchanged by USBFS. Bit 3 of the current token PID is written back to the BD by USBFS.</li> </ul> |

*Table continues on the next page...*

Table 190. Buffer descriptor fields (continued)

| Field                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                              | <ul style="list-style-type: none"> <li>TOK_PID[3]—If the OWN field also becomes 1, then the BD remains owned by USBFS indefinitely; when written by USB, it serves as TOK_PID[3]. Typically, this field is 1 with ISO endpoints feeding a FIFO. The microprocessor is not informed that a token has been processed. Transfer the data to or from the FIFO. When KEEP becomes 1, the NINC field usually becomes 1 to prevent address increment.</li> </ul> <p>0 or 1 USBFS writes back bit 3 of the current token PID to the BD.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 4<br>NINC/<br>TOK_PID[2]     | <p>No Increment (NINC)</p> <p>Disables the DMA engine address increment. This forces the DMA engine to read or write from the same address. This is useful for endpoints when data is <i>read from</i> or <i>written to</i> a single location (such as a FIFO). Typically this field becomes 1 with the KEEP field for ISO endpoints that are interfacing to a FIFO.</p> <p>0 USBFS writes bit 2 of the current token PID to the BD.</p> <p>1 This bit is unchanged by USBFS.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3<br>DTS/<br>TOK_PID[1]      | <p>Enables USBFS to perform data toggle synchronization when you write 1 to this field.</p> <ul style="list-style-type: none"> <li>If KEEP = 0, then bit 1 of the current token PID is written back to the BD.</li> <li>If KEEP = 1, then this field is unchanged by USBFS.</li> </ul> <p>0 Data toggle synchronization is disabled.</p> <p>1 Enables USBFS to perform data toggle synchronization.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2<br>BDT_STALL<br>TOK_PID[0] | <p>Causes USBFS to issue a STALL handshake if the SIE receives a token that uses the BDT in this location when you write 1 to this field. The SIE does not consume the BDT (the OWN field remains 1 and the rest of the BDT is unchanged) when a BDT_STALL field becomes 1.</p> <ul style="list-style-type: none"> <li>If KEEP = 0, write back bit 0 of the current token PID to the BD.</li> <li>If KEEP = 1, then this field is unchanged by USBFS.</li> </ul> <p>0 No stall issued.</p> <p>1 The SIE does not consume the BDT (the OWN field remains 1, and the rest of the BDT is unchanged).</p> <p>Writing 1 to BDT_STALL also causes the corresponding <a href="#">USB_ENDPTn[EPSTALL]</a> to become 1. This causes USB OTG to issue a STALL handshake for both directions of the associated endpoint. To clear the stall condition:</p> <ol style="list-style-type: none"> <li>Write 0 to the associated <a href="#">USB_ENDPTn[EPSTALL]</a>.</li> <li>Write the BDT to clear OWN and BDT_STALL.</li> </ol> |
| TOK_PID[n]                   | <p>Bits [5:2] can also represent the current token PID. When a transfer completes, USBFS writes back the current token PID into the BD. The values written back are the token PID values from the USB specification:</p> <ul style="list-style-type: none"> <li>1h for an OUT token.</li> <li>9h for an IN token.</li> <li>Dh for a SETUP token.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

*Table continues on the next page...*

Table 190. Buffer descriptor fields (continued)

| Field           | Description                                                                                                                                       |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 1–0<br>Reserved | Reserved                                                                                                                                          |
| ADDR[31:0]      | Address<br><br>Represents the 32-bit buffer address in system memory; this address must also be 32-bit aligned. USBFS does not change this field. |

### 35.3.2.4 USB transaction

When USBFS transmits or receives data, it computes the BDT address using the address generation shown in [Addressing BDT entries](#).

If OWN = 1, then the following process occurs:

1. USBFS reads the BDT.
2. The SIE transfers the data via the DMA to or from the buffer pointed to by [Address \(ADDR\)](#) of the BD.
3. When the TOKEN completes, USBFS updates the BDT, and if KEEP = 0, then USBFS changes the OWN field to 0.
4. Update the STAT register, and the TOK\_DNE interrupt occurs.
5. When the processor processes the TOK\_DNE interrupt, it reads from the status register all the information required to process the endpoint.
6. At this point, the processor allocates a new BD so that you can transmit or receive the additional USB data for that endpoint and then processes the last BD.

The following figure shows how a typical USB token is processed after the BDT is read and OWN = 1.



Figure 158. USB token transaction

USB has two sources for the DMA overrun error:

- **Memory latency:** The memory latency may be too high and cause the receive FIFO to overflow. This is predominantly a hardware performance issue, usually caused by transient memory access issues.

- Oversized packets:** The packet received may be larger than the negotiated MaxPacket size. Typically, a software bug causes this. The USB specification is ambiguous for DMA overrun errors due to oversized data packets because it assumes correct software drivers on both sides. NAKing the packet can result in the retransmission of the already oversized packet data. Therefore, in response to oversized packets, the USB core continues ACKing the packet for non-isochronous transfers.

Table 191. USB responses to DMA overrun errors

| Errors due to memory latency                                                                                                                                                                                                    | Errors due to oversized packets                                                                                                                                                                         |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Non-acknowledgment (NAK) or bus timeout (BTO) — See bit 4 in <a href="#">Error Interrupt Status (ERRSTAT)</a> as appropriate for the class of transaction.                                                                      | Continues acknowledging (ACKing) the packet for non-isochronous transfers.                                                                                                                              |
| —                                                                                                                                                                                                                               | Clip the data written to memory to the MaxPacket size so as not to corrupt system memory.                                                                                                               |
| <a href="#">ERRSTAT[DMAERR]</a> becomes 1 for Device mode of operation. Depending on the INTENB and ERRENB register's values, the core may assert an interrupt to notify the processor of the DMA error.                        | Asserts <a href="#">ERRSTAT[DMAERR]</a> , which can trigger an interrupt and <a href="#">ISTAT[TOKDNE]</a> fires.<br>The TOK_PID field of the BDT is not 1111 because the DMAERR is not due to latency. |
| <ul style="list-style-type: none"> <li>In Device mode: The BDT is not written back nor <a href="#">ISTAT[TOKDNE]</a> triggered because it is assumed that a second attempt is queued and will succeed in the future.</li> </ul> | The packet length field written back to the BDT is the MaxPacket value representing the length of the clipped data written to memory.                                                                   |
| From here, you can decide an appropriate course of action for future transactions, such as stalling the endpoint, canceling the transfer, disabling the endpoint, and others.                                                   |                                                                                                                                                                                                         |

### 35.3.3 Operations

#### 35.3.3.1 Device mode FIRC operation

The following are the FIRC initialization code steps for USB crystal-less Device mode operation:

1. Enable the FIRC nominal 48 MHz clock by ensuring that the FIRCSR[FIRCCEN] and FIRCTCFG[TRIMSRC] fields in the SCG registers have the correct values for crystal-less FS USB Device mode operation.
2. Enable the USB clock recovery tuning by writing 1 to [CLK\\_RECOVER\\_CTRL\[CLOCK\\_RECOVER\\_EN\]](#).
3. Complete the configuration of the USB clock recovery logic by writing 1 to [CLK\\_RECOVER\\_IRC\\_EN\[IRC\\_EN\]](#).
4. This chip does not have alternate USB input clock sources from clock muxes, so no additional 48 MHz clock path configuration is required.

#### 35.3.3.2 USB and VREGIN pin status detection

This device does not have a dedicated VBUS detect pin. Still, it does have the capability through [CONTROL\[SESS\\_VLD\]](#) to report the status of VBUS using one of two monitoring methods with different package pins. The choice between the two VBUS monitoring methods is made with [CONTROL\[VBUS\\_SOURCE\\_SEL\]](#). For VBUS detection, use a specified GPIO pin for both bus-powered and self-powered USB cases. If the GPIO pins on this device do not directly support a 5 V input, use an external resistive voltage divider to keep the input voltage within the valid range if you use the GPIO pin method for VBUS detection. The voltage status of the VDD\_LDO\_USB pin is passed internally from the USB VREG to the USB FS subsystem, so no additional board connections are required if you choose the VBUS detection method.

For this chip, the specified GPIO package pin for VBUS monitoring is PTB6 configured in mux mode ALT2.

This device does not have a dedicated OTG ID detect pin. For OTG ID pin detection, if needed, use one of the GPIO pins connected to the WUU configured as an input pin with pullup enabled.

### 35.3.3.3 LPUART over USB capability

This device supports a connection whereby any LPUART may connect to the FS USB physical layer (and the USB controller disconnected) to allow simple debugging capabilities for applications that do not have direct physical access to other LPUART Tx/Rx pins.

When you write 1 to [USBCTRL\[UARTSEL\]](#), the selected LPUART connects to the FS USB physical layer. This configures the FS USB0\_DP/DM signals to configure as normal LPUART signals, which do not operate in differential mode. When [USBCTRL\[UARTCHLS\]](#) becomes 0, FS USB0\_DP/DM signal pins are configured for LPUART Tx/Rx functions respectively. When [USBCTRL\[UARTCHLS\]](#) becomes 1, FS USB0\_DP/DM signal pins are configured for LPUART Rx/Tx functions.

### 35.3.3.4 Lane reversal feature

This device supports lane reversal for the USB0\_DP and USB0\_DM pins for flexibility in PC board design depending on the USB receptacle type and location choices.

[USBCTRL\[DPDM\\_LANE\\_REVERSE\]](#) controls the lane reversal. After [USBCTRL\[DPDM\\_LANE\\_REVERSE\]](#) becomes 0, the USB0\_DP and USB0\_DM external package pins have their normal roles. After [USBCTRL\[DPDM\\_LANE\\_REVERSE\]](#) becomes 1, the I/O pin roles are switched so that the USB0\_DP external package pin operates as USB\_DM and the USB0\_DM external package pin operates as USB\_DP.

Lane reversal impacts all USB standard data communication functions along with battery charging detection and signaling. Lane reversal does **not** impact LPUART over USB mode selections for USB0\_DP/DM pin functions because there is already a pin configuration for that mode using [USBCTRL\[UARTCHLS\]](#).

## 35.3.4 Modes of operation

USBFS includes the following main modes of operation:

- Active mode
- Low-Power mode

### 35.3.4.1 Active mode

This is the basic mode of operation.

A USBFS core-centric nomenclature is used to describe the direction of the data transfer between USBFS core and USB. Throughout this chapter:

- Receive (or "Rx") describes transfers that move data from USB to memory.
- Transmit (or "Tx") describes transfers that move data from memory to USB.

The following table shows the data directions for USBFS.

Table 192. Data direction for USB host or USB target

| Rx           | Tx |
|--------------|----|
| OUT or SETUP | IN |

### 35.3.4.2 Low-Power mode

The USB controller supports Sleep mode, Deep Sleep mode, and Power Down mode to save power consumption.

When the USB subsystem detects no activity on the USB bus for more than 3 ms, [ISTAT\[SLEEP\]](#) becomes 1. This field can cause an interrupt, and you decide on the appropriate action.

Waking from a Sleep Low-Power mode when the USB subsystem is powered occurs through an asynchronous interrupt triggered by activity on the USB bus. Writing 1 to [USBTRC0\[USBRESMEN\]](#) enables this function.

The following wakeup features are also supported:

- In Active and Sleep modes, the USB controller can generate an interrupt on VREGIN detection using [MISCCTRL\[VFEDG\\_EN\]](#), [MISCCTRL\[VREDG\\_EN\]](#), [USBTRC0\[VFEDG\\_DET\]](#), and [USBTRC0\[VREDG\\_DET\]](#).
- In Deep Sleep and Power Down modes, VDD\_LDO\_USB is an input pin to WUU, and a transition on it can generate a wakeup.
- In Deep Sleep and Power Down modes, the GPIO pins chosen to detect VBUS and OTG ID are also input to WUU, so transitions on them can generate a wakeup.

In Deep Power Down mode, the pads become isolated, and USB bus activity cannot wake the system.

### 35.3.5 Clocking

This section describes clocks and special clocking requirements of USBFS.

Table 193. Clocking

| Clock name     | Description                                                        |
|----------------|--------------------------------------------------------------------|
| Bus clock      | The bus clock is system-dependent. It must be greater than 24 MHz. |
| Function clock | USB 48 MHz functional clock                                        |

### 35.3.6 Reset

#### Chip reset

The logic and registers for USBFS reset to their default states on a chip reset.

#### Software reset

USBFS implements a software reset field in its control register. See [USBTRC0\[USBRESET\]](#) for more information.

### 35.3.7 Interrupts

The following table illustrates the status flags that can generate USBFS interrupts.

Table 194. Interrupts

| Flag                   | Description                       | Low-power wakeup |
|------------------------|-----------------------------------|------------------|
| <a href="#">STALL</a>  | Stall handshake flag              | No               |
| <a href="#">RESUME</a> | Resume flag                       | No               |
| <a href="#">SLEEP</a>  | Sleep flag                        | No               |
| <a href="#">TOKDNE</a> | Token processing done flag        | No               |
| <a href="#">SOFTOK</a> | SOF token flag                    | No               |
| <a href="#">ERROR</a>  | Error flag                        | No               |
| <a href="#">USBRST</a> | USB reset flag                    | No               |
| <a href="#">BTSERR</a> | Bit stuff error flag              | No               |
| <a href="#">OWNERR</a> | BD unavailable error flag         | No               |
| <a href="#">DMAERR</a> | DMA access error flag             | No               |
| <a href="#">BTOERR</a> | Bus turnaround timeout error flag | No               |
| <a href="#">DFN8</a>   | Data field bit width error flag   | No               |

*Table continues on the next page...*

Table 194. Interrupts (continued)

| Flag           | Description                     | Low-power wakeup |
|----------------|---------------------------------|------------------|
| CRC16          | CRC16 error flag                | No               |
| CRC5EOF        | EOF error flag                  | No               |
| PIDERR         | PID error flag                  | No               |
| USB_RESUME_INT | Asynchronous resume wakeup flag | Yes              |
| VFEDG_DET      | VREGIN falling edge flag        | Yes              |
| VREDG_DET      | VREGIN rising edge flag         | Yes              |
| OVF_ERROR      | Frequency trim adjustment flag  | No               |

### 35.3.8 DMA

USBFS provides an integrated DMA controller that transfers the packet data to and from memory. The DMA controller allows USB endpoint data to transfer very efficiently, limiting processor involvement.

## 35.4 External signals

This section describes clocks and special clocking requirements of USBFS.

Table 195. External signals

| Signal  | Description                            |
|---------|----------------------------------------|
| USB0_DP | USB D+ pin                             |
| USB0_DM | USB D- pin                             |
| VDD_USB | 3.3 V power supply for USB transceiver |

## 35.5 Initialization

For Device mode initialization, see [Device mode operation examples](#).

## 35.6 Application information

### 35.6.1 Device mode operation examples

The following sections list the steps required to perform USB device functions using the USBFS core.

To enable Device mode and discover a connected USB host:

1. Pullup DP ([CONTROL\[DPPULLUPNONOTG\]](#) = 1b).
2. Disable weak pulldown on DP and DM ([USBCTRL\[PDE\]](#) = 0b).
3. Disable suspend ([USBCTRL\[SUSP\]](#) = 1'b0).
4. Clear status flags.
5. Enable USBRST interrupt ([INTEN\[USBRSTEN\]](#) = 1b).
6. Enable USBFS ([CTL\[USBNENOFEN\]](#) = 1'b1).
7. Wait for reset request from USB host ([ISTAT\[USBRST\]](#) = 1b).
8. Detect USBRST interrupt, device connected to USB host.

To complete a packet transfer:

1. Complete all the steps to discover a connected USB host.
2. Set up the endpoint control register for packet transfer ([ENDPT0\[4:0\]](#) = 0dh).
3. Enable TOKDNE interrupt ([INTEN\[TOKDNEEN\]](#) = 1b).
4. Initialize the endpoint BDT in USB RAM including setting OWN = 1b.
5. Clear TXD\_SUSPEND flag (write 1 to clear [CTL\[TXSUSPENDTOKENBUSY\]](#)).
6. Wait packet transfer to complete ([ISTAT\[TOKDNE\]](#) = 1b).
7. Detect TOKDNE interrupt, check BDT and status flags.

## 35.7 Memory map and register definitions

This section provides the memory map and detailed descriptions of all USBFS interface registers.

**NOTE**

[Control \(CTL\)](#), [USB Control \(USBCTRL\)](#), and [USB OTG Control \(CONTROL\)](#) have similar names but these are all separate registers.

### 35.7.1 USBFS register descriptions

#### 35.7.1.1 USBFS memory map

USB0 base address: 400A\_4000h

| Offset | Register                                             | Width<br>(In bits) | Access | Reset value |
|--------|------------------------------------------------------|--------------------|--------|-------------|
| 0h     | <a href="#">Peripheral ID (PERID)</a>                | 8                  | R      | 04h         |
| 4h     | <a href="#">Peripheral ID Complement (IDCOMP)</a>    | 8                  | R      | FBh         |
| 8h     | <a href="#">Peripheral Revision (REV)</a>            | 8                  | R      | 33h         |
| 1Ch    | <a href="#">OTG Control (OTGCTL)</a>                 | 8                  | RW     | 00h         |
| 80h    | <a href="#">Interrupt Status (ISTAT)</a>             | 8                  | RW     | 00h         |
| 84h    | <a href="#">Interrupt Enable (INTEN)</a>             | 8                  | RW     | 00h         |
| 88h    | <a href="#">Error Interrupt Status (ERRSTAT)</a>     | 8                  | RW     | 00h         |
| 8Ch    | <a href="#">Error Interrupt Enable (ERREN)</a>       | 8                  | RW     | 00h         |
| 90h    | <a href="#">Status (STAT)</a>                        | 8                  | R      | 00h         |
| 94h    | <a href="#">Control (CTL)</a>                        | 8                  | RW     | 00h         |
| 98h    | <a href="#">Address (ADDR)</a>                       | 8                  | RW     | 00h         |
| 9Ch    | <a href="#">BDT Page 1 (BDTPAGE1)</a>                | 8                  | RW     | 00h         |
| A0h    | <a href="#">Frame Number Register Low (FRMNUML)</a>  | 8                  | R      | 00h         |
| A4h    | <a href="#">Frame Number Register High (FRMNUMH)</a> | 8                  | R      | 00h         |
| B0h    | <a href="#">BDT Page 2 (BDTPAGE2)</a>                | 8                  | RW     | 00h         |
| B4h    | <a href="#">BDT Page 3 (BDTPAGE3)</a>                | 8                  | RW     | 00h         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset          | Register                                                                            | Width<br>(In bits) | Access | Reset value |
|-----------------|-------------------------------------------------------------------------------------|--------------------|--------|-------------|
| C0h             | Endpoint Control (ENDPT0)                                                           | 8                  | RW     | 00h         |
| C4h             | Endpoint Control (ENDPT1)                                                           | 8                  | RW     | 00h         |
| C8h             | Endpoint Control (ENDPT2)                                                           | 8                  | RW     | 00h         |
| CCh             | Endpoint Control (ENDPT3)                                                           | 8                  | RW     | 00h         |
| D0h             | Endpoint Control (ENDPT4)                                                           | 8                  | RW     | 00h         |
| D4h             | Endpoint Control (ENDPT5)                                                           | 8                  | RW     | 00h         |
| D8h             | Endpoint Control (ENDPT6)                                                           | 8                  | RW     | 00h         |
| DCh             | Endpoint Control (ENDPT7)                                                           | 8                  | RW     | 00h         |
| E0h             | Endpoint Control (ENDPT8)                                                           | 8                  | RW     | 00h         |
| E4h             | Endpoint Control (ENDPT9)                                                           | 8                  | RW     | 00h         |
| E8h             | Endpoint Control (ENDPT10)                                                          | 8                  | RW     | 00h         |
| EC <sub>h</sub> | Endpoint Control (ENDPT11)                                                          | 8                  | RW     | 00h         |
| F0h             | Endpoint Control (ENDPT12)                                                          | 8                  | RW     | 00h         |
| F4h             | Endpoint Control (ENDPT13)                                                          | 8                  | RW     | 00h         |
| F8h             | Endpoint Control (ENDPT14)                                                          | 8                  | RW     | 00h         |
| FC <sub>h</sub> | Endpoint Control (ENDPT15)                                                          | 8                  | RW     | 00h         |
| 100h            | USB Control (USBCTRL)                                                               | 8                  | RW     | C0h         |
| 104h            | USB OTG Observe (OBSERVE)                                                           | 8                  | R      | 50h         |
| 108h            | USB OTG Control (CONTROL)                                                           | 8                  | RW     | 00h         |
| 10Ch            | USB Transceiver Control 0 (USBTRC0)                                                 | 8                  | RW     | 00h         |
| 124h            | Reserved (KEEP_ALIVE_CTRL_RSVD)                                                     | 8                  | RW     | 08h         |
| 128h            | Reserved (KEEP_ALIVE_WKCTRL_RSVD)                                                   | 8                  | RW     | 01h         |
| 12Ch            | Miscellaneous Control (MISCCTRL)                                                    | 8                  | RW     | 00h         |
| 130h            | Peripheral Mode Stall Disable for Endpoints 7 to 0 in IN Direction (STALL_IL_DIS)   | 8                  | RW     | 00h         |
| 134h            | Peripheral Mode Stall Disable for Endpoints 15 to 8 in IN Direction (STALL_IH_DIS)  | 8                  | RW     | 00h         |
| 138h            | Peripheral Mode Stall Disable for Endpoints 7 to 0 in OUT Direction (STALL_OL_DIS)  | 8                  | RW     | 00h         |
| 13Ch            | Peripheral Mode Stall Disable for Endpoints 15 to 8 in OUT Direction (STALL_OH_DIS) | 8                  | RW     | 00h         |
| 140h            | USB Clock Recovery Control (CLK_RECOVER_CTRL)                                       | 8                  | RW     | 00h         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset | Register                                                           | Width<br>(In bits) | Access | Reset value |
|--------|--------------------------------------------------------------------|--------------------|--------|-------------|
| 144h   | FIRC Oscillator Enable (CLK_RECOVER_IRC_EN)                        | 8                  | RW     | 01h         |
| 154h   | Clock Recovery Combined Interrupt Enable (CLK_RECOVER_INT_EN)      | 8                  | RW     | 10h         |
| 15Ch   | Clock Recovery Separated Interrupt Status (CLK_RECOVER_INT_STATUS) | 8                  | RW     | 00h         |

### 35.7.1.2 Peripheral ID (PERID)

#### Offset

| Register | Offset |
|----------|--------|
| PERID    | 0h     |

#### Function

Reads back the value of 04h. This value is defined for the USB peripheral.

#### Diagram



#### Fields

| Field | Function                  |
|-------|---------------------------|
| 7-6   | Reserved                  |
| —     |                           |
| 5-0   | Peripheral Identification |
| ID    |                           |

### 35.7.1.3 Peripheral ID Complement (IDCOMP)

#### Offset

| Register | Offset |
|----------|--------|
| IDCOMP   | 4h     |

**Function**

Indicates the one's complement of [Peripheral ID \(PERID\)](#). For the USB peripheral, the value is FBh.

**Diagram****Fields**

| Field | Function                                                      |
|-------|---------------------------------------------------------------|
| 7-6   | Reserved                                                      |
| —     |                                                               |
| 5-0   | Negative Peripheral ID                                        |
| NID   | Indicates the one's complement of <a href="#">PERID[ID]</a> . |

**35.7.1.4 Peripheral Revision (REV)****Offset**

| Register | Offset |
|----------|--------|
| REV      | 8h     |

**Function**

Indicates the revision number of USBFS.

**Diagram****Fields**

| Field | Function                            |
|-------|-------------------------------------|
| 7-0   | Revision                            |
| REV   | Contains the USBFS revision number. |

### 35.7.1.5 OTG Control (OTGCTL)

#### Offset

| Register | Offset |
|----------|--------|
| OTGCTL   | 1Ch    |

#### Function

Controls the operation of data line termination resistors.

#### Diagram



#### Fields

| Field       | Function                                                           |
|-------------|--------------------------------------------------------------------|
| 7<br>DPHIGH | D+ Data Line Pullup Resistor Enable<br>0b - Disable<br>1b - Enable |
| 6-0<br>—    | Reserved                                                           |

### 35.7.1.6 Interrupt Status (ISTAT)

#### Offset

| Register | Offset |
|----------|--------|
| ISTAT    | 80h    |

#### Function

Contains flag fields for each of the interrupt sources within USBFS. Each of these fields is qualified with their respective interrupt enable fields.

**Diagram**

| Bits  | 7     | 6 | 5      | 4     | 3      | 2      | 1     | 0      |
|-------|-------|---|--------|-------|--------|--------|-------|--------|
| R     | STALL | 0 | RESUME | SLEEP | TOKDNE | SOFTOK | ERROR | USBRST |
| W     | W1C   |   | W1C    | W1C   | W1C    | W1C    | W1C   | W1C    |
| Reset | 0     | 0 | 0      | 0     | 0      | 0      | 0     | 0      |

**Fields**

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>STALL  | <p>Stall Interrupt Flag</p> <p>In Device mode, becomes 1 when SIE sent a STALL handshake.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - Interrupt did not occur</li> <li>1b - Interrupt occurred</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul>                                                                |
| 6<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 5<br>RESUME | <p>Resume Flag</p> <p>Indicates when a K-state is observed on the DP or DM signals for 2.5 µs. You must disable this interrupt when not in Suspend mode.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - Interrupt did not occur</li> <li>1b - Interrupt occurred</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul> |
| 4<br>SLEEP  | <p>Sleep Flag</p> <p>Indicates when USBFS detects a constant idle on the USB bus for 3 ms. Activity on the USB bus resets the sleep timer.</p>                                                                                                                                                                                                                                                                                                                                                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | <p style="text-align: center;"><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - Interrupt did not occur</li> <li>1b - Interrupt occurred</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3<br>TOKDNE | <p>Current Token Processing Flag</p> <p>Indicates when the current token being processed has completed. The processor must immediately read <a href="#">Status (STAT)</a> to determine the EndPoint and BD used for this token. Clearing this flag causes one of the following events:</p> <ul style="list-style-type: none"> <li>• STAT becomes 0.</li> <li>• USBFS loads the STAT holding register into <a href="#">Status (STAT)</a>.</li> </ul> <p style="text-align: center;"><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - Not processed</li> <li>1b - Processed</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul> |
| 2<br>SOFTOK | <p>Start Of Frame (SOF) Token Flag</p> <p>Indicates when USBFS receives a SOF token.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - Did not receive</li> <li>1b - Received</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul>                                                                                                                                                                                                                                                                                                                                                           |
| 1           | Error Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ERROR       | <p>Indicates when any of the error conditions within <a href="#">Error Interrupt Status (ERRSTAT)</a> occur. The processor must then read <a href="#">Error Interrupt Status (ERRSTAT)</a> to determine the source of the error.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - Error did not occur</li> <li>1b - Error occurred</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul>                                                                                                                            |
| 0<br>USBRST | <p>USB Reset Flag</p> <p>Indicates when USBFS detects a valid USB reset. This informs the processor that it must write 00h into the address register and enable endpoint 0.</p> <p>This field becomes 1 after a USB reset is detected for 2.5 µs. This field does not become 1 again until the USB reset condition is removed and the USB reset condition is reasserted.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - Not detected</li> <li>1b - Detected</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul> |

### 35.7.1.7 Interrupt Enable (INTEN)

#### Offset

| Register | Offset |
|----------|--------|
| INTEN    | 84h    |

#### Function

Enables interrupt sources within USBFS. Writing 1 to any of these fields enables the respective interrupt source in [Interrupt Status \(ISTAT\)](#).

**Diagram**

| Bits | 7       | 6 | 5        | 4       | 3        | 2        | 1       | 0        |
|------|---------|---|----------|---------|----------|----------|---------|----------|
| R    | STALLEN | 0 | RESUMEEN | SLEEPEN | TOKDNEEN | SOFTOKEN | ERROREN | USBRSTEN |
| W    | 0       | 0 | 0        | 0       | 0        | 0        | 0       | 0        |

Reset

**Fields**

| Field         | Function                                                                                |
|---------------|-----------------------------------------------------------------------------------------|
| 7<br>STALLEN  | STALL Interrupt Enable<br>Enables the STALL interrupt.<br>0b - Disable<br>1b - Enable   |
| 6<br>—        | Reserved                                                                                |
| 5<br>RESUMEEN | RESUME Interrupt Enable<br>Enables the RESUME interrupt.<br>0b - Disable<br>1b - Enable |
| 4<br>SLEEPEN  | SLEEP Interrupt Enable<br>Enables the SLEEP interrupt.<br>0b - Disable<br>1b - Enable   |
| 3<br>TOKDNEEN | TOKDNE Interrupt Enable<br>Enables the TOKDNE interrupt.<br>0b - Disable<br>1b - Enable |
| 2<br>SOFTOKEN | SOFTOK Interrupt Enable<br>Enables the SOFTOK interrupt.<br>0b - Disable<br>1b - Enable |
| 1<br>ERROREN  | ERROR Interrupt Enable<br>Enables the ERROR interrupt.<br>0b - Disable<br>1b - Enable   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                        |
|---------------|-------------------------------------------------------------------------------------------------|
| 0<br>USBRSTEN | USBRST Interrupt Enable<br><br>Enables the USBRST interrupt.<br><br>0b - Disable<br>1b - Enable |

### 35.7.1.8 Error Interrupt Status (ERRSTAT)

#### Offset

| Register | Offset |
|----------|--------|
| ERRSTAT  | 88h    |

#### Function

Enables interrupt error sources within USBFS. Each of these fields are qualified with their respective error enable fields.

All fields of this register are logically OR'ed together and the result placed in [ISTAT\[ERROR\]](#).

Each field becomes 1 as soon as you detect the error condition; therefore, the interrupt does not typically correspond with the end of a token being processed.

#### Diagram

| Bits  | 7                      | 6                      | 5                      | 4                      | 3                    | 2                     | 1                       | 0                      |
|-------|------------------------|------------------------|------------------------|------------------------|----------------------|-----------------------|-------------------------|------------------------|
| R     | <a href="#">BTSERR</a> | <a href="#">OWNERR</a> | <a href="#">DMAERR</a> | <a href="#">BTOERR</a> | <a href="#">DFN8</a> | <a href="#">CRC16</a> | <a href="#">CRC5EOF</a> | <a href="#">PIDERR</a> |
| W     | W1C                    | W1C                    | W1C                    | W1C                    | W1C                  | W1C                   | W1C                     | W1C                    |
| Reset | 0                      | 0                      | 0                      | 0                      | 0                    | 0                     | 0                       | 0                      |

#### Fields

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                    |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>BTSERR | Bit Stuff Error Flag<br><br>Indicates when a bit stuff error is detected. If this field is 1, then the corresponding packet is rejected due to the error.<br><br><b>NOTE</b><br>This field behaves differently for register reads and writes.<br><br>When reading<br>0b - Packet not rejected due to the error<br>1b - Packet rejected due to the error<br><br>When writing |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | <p>0b - No effect<br/>1b - Clear the flag</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 6<br>OWNERR | <p>BD Unavailable Error Flag<br/>Indicates when USBFS operates in Peripheral mode. This field becomes 1 if USBFS requires a new BD for SETUP, ISO IN, or ISO OUT transfer when a new BD is not available.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading<br/>0b - Interrupt did not occur<br/>1b - Interrupt occurred<br/>When writing<br/>0b - No effect<br/>1b - Clear the flag</p>                                                                                                                                                                                                    |
| 5<br>DMAERR | <p>DMA Access Error Flag<br/>Indicates if USBFS has requested a DMA access to read a new BDT, but has not been given the bus before it needs to receive or transmit data.</p> <ul style="list-style-type: none"> <li>• If processing a transit transfer, this causes a transmit data underflow condition.</li> <li>• If processing a receive transfer, this causes a receive data overflow condition.</li> </ul> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading<br/>0b - Interrupt did not occur<br/>1b - Interrupt occurred<br/>When writing<br/>0b - No effect<br/>1b - Clear the flag</p> |
| 4<br>BTOERR | <p>Bus Turnaround Timeout Error Flag<br/>Indicates when a bus turnaround timeout error occurs. USBFS contains a bus turnaround timer that keeps track of the amount of time elapsed between the token and data phases of a SETUP or OUT TOKEN or the data and handshake phases of a IN TOKEN. A bus turnaround timeout error occurs if more than 16 bit times are counted from the previous EOP before a transition from IDLE.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p>                                                                                                        |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | <p>0b - Not timed out<br/>1b - Timed out</p> <p>When writing<br/>0b - No effect<br/>1b - Clear the flag</p>                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3<br>DFN8    | <p>Data Field Not 8 Bits Flag<br/>Indicates if the data field received was not 8 bits in length. USB Specification 1.0 requires that data fields be an integer number of bytes. If the data field is not an integer number of bytes, then this field becomes 1.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading<br/>0b - Integer number of bytes<br/>1b - Not an integer number of bytes</p> <p>When writing<br/>0b - No effect<br/>1b - Clear the flag</p> |
| 2<br>CRC16   | <p>CRC16 Error Flag<br/>Indicates when a data packet is rejected due to a CRC16 error.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading<br/>0b - Not rejected<br/>1b - Rejected</p> <p>When writing<br/>0b - No effect<br/>1b - Clear the flag</p>                                                                                                                                                                                                           |
| 1<br>CRC5EOF | <p>CRC5 Error or End of Frame Error Flag<br/>When USBFS operates in Peripheral mode, this interrupt detects CRC5 errors in the token packets generated by the host. If this field is 1, then the token packet is rejected because of a CRC5 error.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p>                                                                                                                                                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                               |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | <p>0b - Interrupt did not occur<br/>1b - Interrupt occurred</p> <p>When writing</p> <p>0b - No effect<br/>1b - Clear the flag</p>                                                                                                                                                                                      |
| 0<br>PIDERR | <p>PID Error Flag<br/>Indicates when the PID check field fails.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <p>0b - Did not fail<br/>1b - Failed</p> <p>When writing</p> <p>0b - No effect<br/>1b - Clear the flag</p> |

### 35.7.1.9 Error Interrupt Enable (ERREN)

#### Offset

| Register | Offset |
|----------|--------|
| ERREN    | 8Ch    |

#### Function

Enables the error interrupt sources within USBFS.

Writing 1 to any of these fields enables the respective interrupt source in ERRSTAT.

Each field becomes 1 as soon as the error condition is detected; therefore, the interrupt does not typically correspond with the end of a token processed.

**Diagram**

| Bits | 7        | 6        | 5        | 4        | 3      | 2       | 1          | 0        |
|------|----------|----------|----------|----------|--------|---------|------------|----------|
| R    | BTSERREN | OWNERREN | DMAERREN | BTOERREN | DFN8EN | CRC16EN | CRC5EOF... | PIDERREN |
| W    | 0        | 0        | 0        | 0        | 0      | 0       | 0          | 0        |

Reset

**Fields**

| Field          | Function                                                                                                                |
|----------------|-------------------------------------------------------------------------------------------------------------------------|
| 7<br>BTSERREN  | BTERR (Bit Stuff Error) Interrupt Enable<br>0b - Disable<br>1b - Enable                                                 |
| 6<br>OWNERREN  | OWNERERR Interrupt Enable<br>This field is valid when USBFS operates in Peripheral mode.<br>0b - Disable<br>1b - Enable |
| 5<br>DMAERREN  | DMAERR Interrupt Enable<br>0b - Disable<br>1b - Enable                                                                  |
| 4<br>BTOERREN  | BTOERR (Bus Timeout Error) Interrupt Enable<br>0b - Disable<br>1b - Enable                                              |
| 3<br>DFN8EN    | DFN8 (Data Field Not Integer Number of Bytes) Interrupt Enable<br>0b - Disable<br>1b - Enable                           |
| 2<br>CRC16EN   | CRC16 Interrupt Enable<br>0b - Disable<br>1b - Enable                                                                   |
| 1<br>CRC5EOFEN | CRC5/EOF Interrupt Enable<br>0b - Disable<br>1b - Enable                                                                |
| 0<br>PIDERREN  | PIDERR Interrupt Enable<br>0b - Disable<br>1b - Enable                                                                  |

### 35.7.1.10 Status (STAT)

#### Offset

| Register | Offset |
|----------|--------|
| STAT     | 90h    |

#### Function

Reports the transaction status within USBFS.

When the processor's interrupt controller receives [ISTAT\[TOKDNE\]](#), you must read [Interrupt Status \(ISTAT\)](#) to determine the status of the previous endpoint communication. The data in this register is valid when the TOKDNE interrupt is asserted. This register is a read window into a group FIFO that USBFS maintains. After USBFS uses a BD, it updates this register.

If you perform another USB transaction before servicing the TOKDNE interrupt, then USBFS stores the status of the next transaction in the STAT FIFO. Thus, STAT is a 4-byte FIFO that allows the processor core to process one transaction when the SIE processes the next transaction. Writing 0 to [ISTAT\[TOKDNE\]](#) causes the SIE to update this register with the contents of the next STAT value. If the data in the STAT holding register is valid, then the SIE immediately reasserts to TOKDNE interrupt.

#### Diagram

| Bits  | 7 | 6    | 5 | 4 | 3  | 2   | 1 | 0 |
|-------|---|------|---|---|----|-----|---|---|
| R     |   | ENPD |   |   | TX | ODD |   | 0 |
| W     |   |      |   |   |    |     |   |   |
| Reset | 0 | 0    | 0 | 0 | 0  | 0   | 0 | 0 |

#### Fields

| Field       | Function                                                                                                                                                                                        |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-4<br>ENDP | Endpoint address<br>Encodes the endpoint address that receives or transmits the previous token. This allows the processor core to determine the BDT entry that the last USB transaction update. |
| 3<br>TX     | Transmit Indicator<br>Indicates whether the most recent transaction was a receive or transmit operation.<br>0b - Receive<br>1b - Transmit                                                       |
| 2<br>ODD    | Odd Bank<br>Indicates whether the last BD that you updated is in the odd bank of the BDT.<br>0b - Not in the odd bank<br>1b - In the odd bank                                                   |
| 1-0<br>—    | Reserved                                                                                                                                                                                        |

### 35.7.1.11 Control (CTL)

#### Offset

| Register | Offset |
|----------|--------|
| CTL      | 94h    |

#### Function

Provides various control and configuration information for USBFS.

#### Diagram



#### Fields

| Field                       | Function                                                                                                                                                                                                                                                                                                                                                      |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>—                      | Reserved                                                                                                                                                                                                                                                                                                                                                      |
| 6<br>SE0                    | Live USB Single-Ended Zero signal                                                                                                                                                                                                                                                                                                                             |
| 5<br>TXSUSPENDT<br>OKENBUSY | TXD Suspend And Token Busy<br><br>In Device mode, disables packet transmission and reception. SIE writes 1 to this field to disable this functionality. SIE does this when a SETUP token is received. This allows you to dequeue any pending packet transactions in the BDT before resuming token processing. Write 0 to this field to allow SIE to continue. |
| 4<br>—                      | Reserved                                                                                                                                                                                                                                                                                                                                                      |
| 3<br>—                      | Reserved                                                                                                                                                                                                                                                                                                                                                      |
| 2<br>RESUME                 | Resume<br><br>Enables USBFS to execute resume signaling when this field becomes 1. This allows USBFS to perform remote wake-up. You must write 1 to this field for the required time and then write 0 to this field.                                                                                                                                          |
| 1<br>ODDRST                 | Odd Reset<br><br>Resets all the BDT ODD ping/pong fields to 0 when you write 1 to this field, which specifies the EVEN BDT bank.                                                                                                                                                                                                                              |

Table continues on the next page...

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                  |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>USBENSOFEN | <p>USB Enable</p> <p>When Device mode is enabled, writing 1 to this field enables USBFS to operate. Writing 0 to this field disables USBFS. Writing 1 to this field causes the SIE to reset all of its <b>STAT[ODD]</b> to the BDTs and also resets most of the logic in the SIE.</p> <p>0b - Disable<br/>1b - Enable</p> |

### 35.7.1.12 Address (ADDR)

#### Offset

| Register | Offset |
|----------|--------|
| ADDR     | 98h    |

#### Function

- In Peripheral mode, this register holds the unique USB address that USBFS decodes. CTL[USBEN] must be 1.
- After the reset input becomes active or USBFS decodes a USB reset signal, this register resets to 00h. This action initializes this register to decode address 00h, as required by the USB specification.

#### Diagram



#### Fields

| Field       | Function                                                                      |
|-------------|-------------------------------------------------------------------------------|
| 7<br>—      | Reserved                                                                      |
| 6-0<br>ADDR | USB Address<br>Defines the USB address that USBFS decodes in Peripheral mode. |

### 35.7.1.13 BDT Page 1 (BDTPAGE1)

#### Offset

| Register | Offset |
|----------|--------|
| BDTPAGE1 | 9Ch    |

#### Function

Provides address bits 15 through 9 of the base address where the current BDT resides in system memory. See [Buffer descriptor table \(BDT\)](#) for more information. The 32-bit BDT base address is always aligned on 512-byte boundaries, so bits 8 through 0 of the base address are always zero.

#### Diagram



#### Fields

| Field        | Function                                                                        |
|--------------|---------------------------------------------------------------------------------|
| 7-1<br>BDTBA | BDT Base Address<br>Provides address bits 15 through 9 of the BDT base address. |
| 0<br>—       | Reserved                                                                        |

### 35.7.1.14 Frame Number Register Low (FRMNUML)

#### Offset

| Register | Offset |
|----------|--------|
| FRMNUML  | A0h    |

#### Function

Works with [Frame Number Register High \(FRMNUMH\)](#) to indicate the 11-bit frame number that determines the address of the BDT in system memory. When you receive [ISTAT\[SOFTOK\]](#), update these registers with the current frame number.

**Diagram****Fields**

| Field | Function               |
|-------|------------------------|
| 7-0   | Frame Number, Bits 0-7 |
| FRM   |                        |

**35.7.1.15 Frame Number Register High (FRMNUMH)****Offset**

| Register | Offset |
|----------|--------|
| FRMNUMH  | A4h    |

**Function**

Works with [Frame Number Register Low \(FRMNUML\)](#) to indicate the 11-bit frame number that determines the address of the BDT in system memory. These registers are updated with the current frame number when you receive [ISTAT\[SOFTOK\]](#).

**Diagram****Fields**

| Field | Function                |
|-------|-------------------------|
| 7-3   | Reserved                |
| —     |                         |
| 2-0   | Frame Number, Bits 8-10 |
| FRM   |                         |

### 35.7.1.16 BDT Page 2 (BDTPAGE2)

#### Offset

| Register | Offset |
|----------|--------|
| BDTPAGE2 | B0h    |

#### Function

Works with [BDT Page 3 \(BDTPAGE3\)](#) to specify address where the current BDT resides in system memory. See [Buffer descriptor table \(BDT\)](#) for more information.

#### Diagram



#### Fields

| Field | Function                                                                      |
|-------|-------------------------------------------------------------------------------|
| 7-0   | BDT Base Address                                                              |
| BDTBA | Provides address bits 23 through 16 of the BDT base address in system memory. |

### 35.7.1.17 BDT Page 3 (BDTPAGE3)

#### Offset

| Register | Offset |
|----------|--------|
| BDTPAGE3 | B4h    |

#### Function

Works with [BDT Page 2 \(BDTPAGE2\)](#) to specify the address where the current BDT resides in system memory. See [Buffer descriptor table \(BDT\)](#) for more information.

**Diagram****Fields**

| Field | Function                                                                      |
|-------|-------------------------------------------------------------------------------|
| 7-0   | BDT Base Address                                                              |
| BDTBA | Provides address bits 31 through 24 of the BDT base address in system memory. |

**35.7.1.18 Endpoint Control (ENDPT0 - ENDPT15)****Offset**

For a = 0 to 15:

| Register | Offset         |
|----------|----------------|
| ENDPTa   | C0h + (a × 4h) |

**Function**

Contains the endpoint control fields for each of the 16 endpoints available within USBFS for a decoded address. The format for these registers is shown in the following figure.

- Endpoint 0 (ENDPT0) is associated with control pipe 0, which is required for all USB functions. Therefore, after a USBRST interrupt occurs, the processor core must write 1 to ENDPT0 to contain 0Dh.
- For control, bulk, and interrupt transfers, [ENDPTn\[EPHSHK\]](#) = 1. For isochronous transfers, [ENDPTn\[EPHSHK\]](#) = 0.
- [ENDPTn\[EPCTLDIS\]](#), [ENDPTn\[EPRXEN\]](#), and [ENDPTn\[EPTXEN\]](#) define if an endpoint is enabled and the endpoint's direction. The endpoint enables and direction control is defined in the following table.

Table 196. Endpoint enable and direction control

| EPCTLDIS | EPRXEN | EPTXEN | Endpoint enable and direction control                                         |
|----------|--------|--------|-------------------------------------------------------------------------------|
| X        | 0      | 0      | Disable endpoint                                                              |
| X        | 0      | 1      | Enable endpoint for transit transfers only                                    |
| X        | 1      | 0      | Enable endpoint for receive transfers only                                    |
| 1        | 1      | 1      | Enable endpoint for receive and transit transfers                             |
| 0        | 1      | 1      | Enable endpoint for receive and transit as well as control (SETUP) transfers. |

**Diagram****Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-5<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4<br>EPCTLDIS | Control Transfer Disable<br><br>Disables control (SETUP) transfers. When this field is 0, control transfers are enabled only if <a href="#">ENDPTn[EPRXEN]</a> and <a href="#">ENDPTn[EPTXEN]</a> are both 1. See <a href="#">Table 196</a> .<br><br>0b - Enable<br>1b - Disable                                                                                                                                                                                |
| 3<br>EPRXEN   | Endpoint for RX transfers enable<br><br>Enables the endpoint for RX transfers. See <a href="#">Table 196</a> .                                                                                                                                                                                                                                                                                                                                                  |
| 2<br>EPTXEN   | Endpoint for TX transfers enable<br><br>Enables the endpoint for TX transfers. See <a href="#">Table 196</a> .                                                                                                                                                                                                                                                                                                                                                  |
| 1<br>EPSTALL  | Endpoint Stalled<br><br>Indicates that the endpoint is stalled. <ul style="list-style-type: none"><li>• This field has priority over all other control fields in this register, but this field is only valid if <a href="#">ENDPTn[EPTXEN]</a> = 1 or <a href="#">ENDPTn[EPRXEN]</a> = 1.</li><li>• Any access to this endpoint causes USBFS to return a STALL handshake.</li><li>• After an endpoint is stalled, the host controller must intervene.</li></ul> |
| 0<br>EPHSHK   | Endpoint Handshaking Enable<br><br>Enables an endpoint to perform handshaking during a transaction to this endpoint when this field becomes 1. This field is generally 1 unless the endpoint is isochronous.                                                                                                                                                                                                                                                    |

**35.7.1.19 USB Control (USBCTRL)****Offset**

| Register | Offset |
|----------|--------|
| USBCTRL  | 100h   |

**Function**

Configures:

- The USB FS transceiver
- LPUART over USB pin mode
- DP and DM lane reversal

**Diagram****Fields**

| Field         | Function                                                                                                                                                                                                                                                                                               |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>SUSP     | Suspend<br>Places the USB transceiver into Suspend state.<br>0b - Not in Suspend state<br>1b - In Suspend state                                                                                                                                                                                        |
| 6<br>PDE      | Pulldown Enable<br>Enables the weak pulldowns on the USB transceiver.<br>0b - Disable on D+ and D-<br>1b - Enable on D+ and D-                                                                                                                                                                         |
| 5<br>UARTCHLS | UART Signal Channel Select<br>Selects the UART signal channel.<br>This field is valid only when you select to use USB signals as UART signals.<br>0b - USB DP and DM signals are used as UART TX/RX.<br>1b - USB DP and DM signals are used as UART RX/TX.                                             |
| 4<br>UARTSEL  | UART Select<br>Selects USB external package pins to be used as UART signals.<br>You must not change this field when USB data communication is active.<br>0b - USB DP and DM external package pins are used for USB signaling.<br>1b - USB DP and DM external package pins are used for UART signaling. |
| 3<br>—        | Reserved                                                                                                                                                                                                                                                                                               |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                      | Function                                                                                                                                                                                                                                                                                                                                                    |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2<br>DPDM_LANE_<br>REVERSE | <p>DP and DM Lane Reversal Control</p> <p>Specifies an external USB DP and DM package pin assignment configuration for your flexibility in board design.</p> <p>You must not change this field when USB data communication is active.</p> <p>0b - Standard USB DP and DM package pin assignment</p> <p>1b - Reverse roles of USB DP and DM package pins</p> |
| 1-0<br>—                   | Reserved                                                                                                                                                                                                                                                                                                                                                    |

### 35.7.1.20 USB OTG Observe (OBSERVE)

#### Offset

| Register | Offset |
|----------|--------|
| OBSERVE  | 104h   |

#### Function

Indicates the state of the pullups and pulldowns at the transceiver, which is useful when interfacing with an external OTG control module via a serial interface.

#### Diagram

| Bits  | 7    | 6    | 5 | 4    | 3 | 2 | 1 | 0 |
|-------|------|------|---|------|---|---|---|---|
| R     | DPPU | DPPD | 0 | DMPD |   |   | 0 |   |
| W     |      |      |   |      |   |   |   |   |
| Reset | 0    | 1    | 0 | 1    | 0 | 0 | 0 | 0 |

#### Fields

| Field     | Function                                                                                                                             |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>DPPU | <p>D+ Pullup</p> <p>Indicates the state of the D+ pullup enable at the USB transceiver.</p> <p>0b - Disabled</p> <p>1b - Enabled</p> |
| 6<br>DPPD | D+ Pulldown                                                                                                                          |
|           | Indicates the state of the D+ pulldown enable at the USB transceiver.                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                              |
|-----------|-----------------------------------------------------------------------------------------------------------------------|
|           | 0b - Disabled<br>1b - Enabled                                                                                         |
| 5<br>—    | Reserved                                                                                                              |
| 4<br>DMPD | D- Pulldown<br>Indicates the state of the D- pulldown enable at the USB transceiver.<br>0b - Disabled<br>1b - Enabled |
| 3-0<br>—  | Reserved                                                                                                              |

### 35.7.1.21 USB OTG Control (CONTROL)

#### Offset

| Register | Offset |
|----------|--------|
| CONTROL  | 108h   |

#### Function

Controls VBUS monitoring and the Device-mode DP pullup in the USBFS transceiver.

#### Diagram



#### Fields

| Field    | Function                                                                                                                      |
|----------|-------------------------------------------------------------------------------------------------------------------------------|
| 7-5<br>— | Reserved                                                                                                                      |
| 4        | DP Pullup in Non-OTG Device Mode<br>Provides control of the DP pullup in USB , if you configure USB in a non-OTG device mode. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DPPULLUPNO<br>NOTG   | 0b - Disable<br>1b - Enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3-2<br>—             | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1<br>SESS_VLD        | <p>VBUS Session Valid status</p> <p>Indicates whether the VBUS monitoring method reports that VBUS is above or below the session-valid threshold.</p> <p><a href="#">CONTROL[VBUS_SOURCE_SEL]</a> specifies which of the following options USBFS uses to monitor the VBUS voltage:</p> <ul style="list-style-type: none"> <li>The input to the 3.3-5 V USB regulator</li> <li>A resistive divider between VBUS and the ground connected to a GPIO pin</li> </ul> <p>0b - Below<br/>1b - Above</p> |
| 0<br>VBUS_SOURCE_SEL | <p>VBUS Monitoring Source Select</p> <p>Specifies the source of the VBUS monitoring signal. This source determines the value of <a href="#">CONTROL[SESS_VLD]</a>.</p> <p>0b - Reserved<br/>1b - Resistive divider attached to a GPIO pin</p>                                                                                                                                                                                                                                                     |

### 35.7.1.22 USB Transceiver Control 0 (USBTRC0)

#### Offset

| Register | Offset |
|----------|--------|
| USBTRC0  | 10Ch   |

#### Function

Controls the following operational aspects that the USB Full-Speed Controller registers do not provide:

- Basic operation of the on-chip USB full-speed transceiver
- USB data connection

**Diagram**

| Bits  | 7          | 6          | 5          | 4          | 3          | 2        | 1          | 0 |
|-------|------------|------------|------------|------------|------------|----------|------------|---|
| R     | VREGIN_... | USBRESM... | VFEDG_D... | VREDG_D... | USB_CLK... | SYNC_DET | USB_RES... |   |
| W     | USBRESET   |            |            |            |            |          |            |   |
| Reset | 0          | 0          | 0          | 0          | 0          | 0        | 0          | 0 |

**Fields**

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>USBRESET   | <p>USB Reset</p> <p>Generates a hard reset to USB . After this field becomes 1 and the reset occurs, this field becomes 0 automatically.</p> <p><b>NOTE</b></p> <p>This field always reads 0. After writing 1 to this field, wait for 2 USB clock cycles before accessing other USB register fields.</p> <p>0b - Normal USBFS operation<br/>1b - Returns USBFS to its reset state</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6<br>VREGIN_STS | <p>VREGIN Status</p> <p>Indicates the VREGIN status.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 5<br>USBRESMEN  | <p>Asynchronous Resume Interrupt Enable</p> <p>Enables the USB asynchronous wake-up from Suspend mode.</p> <p>When this field becomes 1, after detection of resume signaling on the USB bus, it allows USBFS to send an asynchronous wake-up event to the MCU. The MCU then re-enables clocks to USBFS. This is used for low-power Suspend mode when USB module clocks are stopped or when the USB transceiver is in Suspend mode. Async wake-up only works in Device mode.</p> <ul style="list-style-type: none"> <li>The asynchronous resume interrupt differs from the synchronous resume interrupt in that it asynchronously detects K-state using the unfiltered state of the D+ and D- pins.</li> <li>You must only enable the asynchronous resume interrupt after you suspend the transceiver.</li> </ul> <p>0b - Disable<br/>1b - Enable</p> |
| 4<br>VFEDG_DET  | <p>VREGIN Falling Edge Interrupt Detect</p> <p>Detects the VREGIN falling edge interrupt.</p> <p>To enable this field, use USB x_MISCCTRL[VFEDG_EN].</p> <p>0b - Not detected<br/>1b - Detected</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3<br>VREDG_DET  | <p>VREGIN Rising Edge Interrupt Detect</p> <p>Detects the VREGIN rising edge interrupt.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                               | To enable this field, use USB $x$ _MISCCTRL[VREDG_EN].<br>0b - Not detected<br>1b - Detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2<br>USB_CLK_REC<br>OVERY_INT | Combined USB Clock Recovery interrupt status<br>The read-only USB_CLK_RECOVERY_INT field will be set to 1'b1 when any of USB clock recovery interrupt conditions are detected and those interrupts are unmasked. <ul style="list-style-type: none"><li>• The only unmasked USB clock recovery interrupt condition results from an overflow of the frequency trim setting values, indicating that the frequency trim calculated is out of the adjustment range of the FIRC output clock.</li><li>• To clear USB_CLK_RECOVERY_INT bit after it has been set, write 0xFF to register USB_CLK_RECOVER_INT_STATUS.</li></ul> |
| 1<br>SYNC_DET                 | Synchronous USB Interrupt Detect<br>Detects the synchronous USB interrupt.<br>0b - Not detected<br>1b - Detected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0<br>USB_RESUME<br>_INT       | USB Asynchronous Interrupt<br>Indicates whether the interrupt is generated.<br>0b - Not generated<br>1b - Generated because of the USB asynchronous interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

### 35.7.1.23 Reserved (KEEP\_ALIVE\_CTRL\_RSVD)

#### Offset

| Register             | Offset |
|----------------------|--------|
| KEEP_ALIVE_CTRL_RSVD | 124h   |

#### Function

This register is reserved for this SOC.

**Diagram****Fields**

| Field | Function |
|-------|----------|
| 7-5   | Reserved |
| —     |          |
| 4-0   | Reserved |
| —     |          |

**35.7.1.24 Reserved (KEEP\_ALIVE\_WKCTRL\_RSVD)****Offset**

| Register               | Offset |
|------------------------|--------|
| KEEP_ALIVE_WKCTRL_RSVD | 128h   |

**Function**

This register is reserved for this SOC.

**Diagram****Fields**

| Field | Function |
|-------|----------|
| 7-4   | Reserved |
| —     |          |
| 3-0   | Reserved |
| —     |          |

### 35.7.1.25 Miscellaneous Control (MISCCTRL)

#### Offset

| Register | Offset |
|----------|--------|
| MISCCTRL | 12Ch   |

#### Function

Provides additional controls for the USBFS subsystem.

#### Diagram



#### Fields

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>STL_ADJ_EN | <p>USB Peripheral Mode Stall Adjust Enable</p> <p>Specifies that this field is valid only in Peripheral mode. By default (STL_ADJ_EN = 0), when you stall an endpoint (ENDPTn[END_STALL] = 1), both IN and OUT directions of the endpoint are stalled. If this field is 1, then when an endpoint is stalled (ENDPTn[END_STALL] = 1), then the USBx_STALL_xx_DIS registers can control which endpoint direction(s) are affected.</p> <p>0b - If ENDPTn[END_STALL] = 1, both IN and OUT directions for the associated endpoint stalls.<br/>1b - If ENDPTn[END_STALL] = 1, the STALL_xx_DIS registers control which directions for the associated endpoint stalls.</p> |
| 6-5<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 4<br>VFEDG_EN   | <p>VREGIN Falling Edge Interrupt Enable</p> <p>Enables VREGIN falling edge interrupt.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3<br>VREDG_EN   | <p>VREGIN Rising Edge Interrupt Enable</p> <p>Enables VREGIN rising edge interrupt.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2               | OWN Error Detect for ISO IN and ISO OUT Disable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                           |
|------------------|------------------------------------------------------------------------------------------------------------------------------------|
| OWNERRISOD<br>IS | Disables OWN error detect for ISO IN, and ISO out.<br>This field is only valid for Peripheral mode.<br>0b - Enable<br>1b - Disable |
| 1<br>—           | Reserved                                                                                                                           |
| 0<br>—           | Reserved                                                                                                                           |

### 35.7.1.26 Peripheral Mode Stall Disable for Endpoints 7 to 0 in IN Direction (STALL\_IL\_DIS)

#### Offset

| Register     | Offset |
|--------------|--------|
| STALL_IL_DIS | 130h   |

#### Function

Meaningful only in Peripheral mode and when [MISCCTRL\[STL\\_ADJ\\_EN\]](#) = 1.

When you stall an endpoint (ENDPTn[END\_STALL] = 1), the fields in this register enable or disable stalling of the IN direction of the endpoints 7 to 0.

#### Diagram



#### Fields

| Field             | Function                                                                                                                      |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 7<br>STALL_I_DIS7 | Disable Endpoint 7 IN Direction<br>Disables USB Device mode stall for endpoint 7 IN direction.<br>0b - Enable<br>1b - Disable |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field             | Function                                                                                                                      |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------|
| 6<br>STALL_I_DIS6 | Disable Endpoint 6 IN Direction<br>Disables USB Device mode stall for endpoint 6 IN direction.<br>0b - Enable<br>1b - Disable |
| 5<br>STALL_I_DIS5 | Disable Endpoint 5 IN Direction<br>Disables USB Device mode stall for endpoint 5 IN direction.<br>0b - Enable<br>1b - Disable |
| 4<br>STALL_I_DIS4 | Disable Endpoint 4 IN Direction<br>Disables USB Device mode stall for endpoint 4 IN direction.<br>0b - Enable<br>1b - Disable |
| 3<br>STALL_I_DIS3 | Disable Endpoint 3 IN Direction<br>Disables USB Device mode stall for endpoint 3 IN direction.<br>0b - Enable<br>1b - Disable |
| 2<br>STALL_I_DIS2 | Disable Endpoint 2 IN Direction<br>Disables USB Device mode stall for endpoint 2 IN direction.<br>0b - Enable<br>1b - Disable |
| 1<br>STALL_I_DIS1 | Disable Endpoint 1 IN Direction<br>Disables USB Device mode stall for endpoint 1 IN direction.<br>0b - Enable<br>1b - Disable |
| 0<br>STALL_I_DIS0 | Disable Endpoint 0 IN Direction<br>Disables USB Device mode stall for endpoint 0 IN direction.<br>0b - Enable<br>1b - Disable |

### 35.7.1.27 Peripheral Mode Stall Disable for Endpoints 15 to 8 in IN Direction (STALL\_IH\_DIS)

#### Offset

| Register     | Offset |
|--------------|--------|
| STALL_IH_DIS | 134h   |

#### Function

Meaningful only in Peripheral mode and when [MISCCTRL\[STL\\_ADJ\\_EN\]](#) = 1.

When you stall an endpoint (ENDPTn[END\_STALL] = 1), the fields in this register enable or disable stalling of the IN direction of the endpoints 15 to 8.

#### Diagram



#### Fields

| Field              | Function                                                                                                                        |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 7<br>STALL_I_DIS15 | Disable Endpoint 15 IN Direction<br>Disables USB Device mode stall for endpoint 15 IN direction.<br>0b - Enable<br>1b - Disable |
| 6<br>STALL_I_DIS14 | Disable Endpoint 14 IN Direction<br>Disables USB Device mode stall for endpoint 14 IN direction.<br>0b - Enable<br>1b - Disable |
| 5<br>STALL_I_DIS13 | Disable Endpoint 13 IN Direction<br>Disables USB Device mode stall for endpoint 13 IN direction.<br>0b - Enable<br>1b - Disable |
| 4<br>STALL_I_DIS12 | Disable Endpoint 12 IN Direction<br>Disables USB Device mode stall for endpoint 12 IN direction.<br>0b - Enable<br>1b - Disable |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field              | Function                                                                                                                        |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 3<br>STALL_I_DIS11 | Disable Endpoint 11 IN Direction<br>Disables USB Device mode stall for endpoint 11 IN direction.<br>0b - Enable<br>1b - Disable |
| 2<br>STALL_I_DIS10 | Disable Endpoint 10 IN Direction<br>Disables USB Device mode stall for endpoint 10 IN direction.<br>0b - Enable<br>1b - Disable |
| 1<br>STALL_I_DIS9  | Disable Endpoint 9 IN Direction<br>Disables USB Device mode stall for endpoint 9 IN direction.<br>0b - Enable<br>1b - Disable   |
| 0<br>STALL_I_DIS8  | Disable Endpoint 8 IN Direction<br>Disables USB Device mode stall for endpoint 8 IN direction.<br>0b - Enable<br>1b - Disable   |

### 35.7.1.28 Peripheral Mode Stall Disable for Endpoints 7 to 0 in OUT Direction (STALL\_OI\_DIS)

#### Offset

| Register     | Offset |
|--------------|--------|
| STALL_OI_DIS | 138h   |

#### Function

Meaningful only in Peripheral mode and when [MISCCTRL\[STL\\_ADJ\\_EN\]](#) = 1.

When you stall an endpoint (ENDPTn[END\_STALL] = 1), the fields in this register enable or disable stalling of the OUT direction for the endpoints 7 to 0.

**Diagram**

| Bits | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0          |
|------|------------|------------|------------|------------|------------|------------|------------|------------|
| R    | STALL_O... |
| W    | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          |

Reset

**Fields**

| Field             | Function                                                                                                                        |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 7<br>STALL_O_DIS7 | Disable Endpoint 7 OUT Direction<br>Disables USB Device mode stall for endpoint 7 OUT direction.<br>0b - Enable<br>1b - Disable |
| 6<br>STALL_O_DIS6 | Disable Endpoint 6 OUT Direction<br>Disables USB Device mode stall for endpoint 6 OUT direction.<br>0b - Enable<br>1b - Disable |
| 5<br>STALL_O_DIS5 | Disable Endpoint 5 OUT Direction<br>Disables USB Device mode stall for endpoint 5 OUT direction.<br>0b - Enable<br>1b - Disable |
| 4<br>STALL_O_DIS4 | Disable Endpoint 4 OUT Direction<br>Disables USB Device mode stall for endpoint 4 OUT direction.<br>0b - Enable<br>1b - Disable |
| 3<br>STALL_O_DIS3 | Disable Endpoint 3 OUT Direction<br>Disables USB Device mode stall for endpoint 3 OUT direction.<br>0b - Enable<br>1b - Disable |
| 2<br>STALL_O_DIS2 | Disable Endpoint 2 OUT Direction<br>Disables USB Device mode stall for endpoint 2 OUT direction.<br>0b - Enable<br>1b - Disable |
| 1<br>STALL_O_DIS1 | Disable Endpoint 1 OUT Direction<br>Disables USB Device mode stall for endpoint 1 OUT direction.                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field             | Function                                                                                                                        |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------|
|                   | 0b - Enable<br>1b - Disable                                                                                                     |
| 0<br>STALL_O_DIS0 | Disable Endpoint 0 OUT Direction<br>Disables USB Device mode stall for endpoint 0 OUT direction.<br>0b - Enable<br>1b - Disable |

### 35.7.1.29 Peripheral Mode Stall Disable for Endpoints 15 to 8 in OUT Direction (STALL\_OH\_DIS)

#### Offset

| Register     | Offset |
|--------------|--------|
| STALL_OH_DIS | 13Ch   |

#### Function

Meaningful only in Peripheral mode and when [MISCCTRL\[STL\\_ADJ\\_EN\] = 1](#).

When you stall an endpoint (ENDPTn[END\_STALL] = 1), the fields in this register enable or disable stalling of the OUT direction for the endpoints 15 to 8.

#### Diagram



#### Fields

| Field                  | Function                                                                                                                          |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 7<br>STALL_O_DIS1<br>5 | Disable Endpoint 15 OUT Direction<br>Disables USB Device mode stall for endpoint 15 OUT direction.<br>0b - Enable<br>1b - Disable |
| 6<br>STALL_O_DIS1<br>4 | Disable Endpoint 14 OUT Direction<br>Disables USB Device mode stall for endpoint 14 OUT direction.                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                  | Function                                                                                                                          |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
|                        | 0b - Enable<br>1b - Disable                                                                                                       |
| 5<br>STALL_O_DIS1<br>3 | Disable Endpoint 13 OUT Direction<br>Disables USB Device mode stall for endpoint 13 OUT direction.<br>0b - Enable<br>1b - Disable |
| 4<br>STALL_O_DIS1<br>2 | Disable endpoint 12 OUT direction<br>Disables USB Device mode stall for endpoint 12 OUT direction.<br>0b - Enable<br>1b - Disable |
| 3<br>STALL_O_DIS1<br>1 | Disable Endpoint 11 OUT Direction<br>Disables USB Device mode stall for endpoint 11 OUT direction.<br>0b - Enable<br>1b - Disable |
| 2<br>STALL_O_DIS1<br>0 | Disable Endpoint 10 OUT Direction<br>Disables USB Device mode stall for endpoint 10 OUT direction.<br>0b - Enable<br>1b - Disable |
| 1<br>STALL_O_DIS9      | Disable Endpoint 9 OUT Direction<br>Disables USB Device mode stall for endpoint 9 OUT direction.<br>0b - Enable<br>1b - Disable   |
| 0<br>STALL_O_DIS8      | Disable Endpoint 8 OUT Direction<br>Disables USB Device mode stall for endpoint 0 OUT direction.<br>0b - Enable<br>1b - Disable   |

### 35.7.1.30 USB Clock Recovery Control (CLK\_RECOVER\_CTRL)

#### Offset

| Register         | Offset |
|------------------|--------|
| CLK_RECOVER_CTRL | 140h   |

**Function**

Controls the crystal-less USB clock mode in which the internal FIRC oscillator is tuned to match the clock extracted from the incoming USB data stream.

**You must configure the FIRC internal oscillator module in the SCG module and enable SOF frequency tuning in this register and FIRC Oscillator Enable (CLK\_RECOVER\_IRC\_EN) for this mode.**

**Diagram**

| Bits | 7          | 6          | 5          | 4 | 3          | 2        | 1        | 0        |
|------|------------|------------|------------|---|------------|----------|----------|----------|
| R    | CLOCK_R... | RESET_R... | RESTART... | 0 | TRIM_IN... | Reserved | Reserved | Reserved |
| W    | 0          | 0          | 0          | 0 | 0          | 0        | 0        | 0        |

Reset

**Fields**

| Field                              | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>CLOCK_REC<br>VER_EN           | Crystal-Less USB Enable<br><br>Enables the frequency trimming logic for the FIRC module to generate clocks for crystal-less FS USB Device mode operation. You must initialize the FIRCCSR[FIRCCEN] and FIRCTCFG[TRIMSRC] to enable the FIRC module itself. Then this field and <a href="#">CLK_RECOVER_IRC_EN[IRC_EN]</a> must become 1 before using the crystal-less USB clock configuration.<br><br>0b - Disable<br>1b - Enable                                                                                                                                                                                                                                                       |
| 6<br>RESET_RESU<br>ME_ROUGH_E<br>N | Reset or Resume to Rough Phase Enable<br><br>Indicates that the clock recovery block tracks the FIRC to get an accurate 48 MHz clock. It has 2 phases after you enable <a href="#">CLK_RECOVER_CTRL[CLOCK_RECOVER_EN]</a> , rough phase and tracking phase. The step to fine-tune the FIRC by adjusting the trim fine value differs during these 2 phases. The rough step-in phase is larger than that in the tracking phase. Switch back to the rough stage whenever a USB bus reset or bus resume occurs.<br><br>0b - Always works in tracking phase after the first time rough phase, to track transition.<br>1b - Go back to rough stage whenever a bus reset or bus resume occurs. |
| 5<br>RESTART_IFR<br>TRIM_EN        | Restart from IFR Trim Value<br><br>FIRC has a default trim fine value whose default value is factory trimmed (the IFR trim value). The clock recover block tracks the clock's accuracy at 48 MHz and keeps updating the trim fine value accordingly.<br><br>0b - Trim fine adjustment always works based on the previous updated trim fine value.<br>1b - Trim fine restarts from the IFR trim value whenever you detect bus_reset or bus_resume or deassert module enable.                                                                                                                                                                                                             |
| 4<br>—                             | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3                                  | Selects the source for the initial FIRC trim fine value used after a reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field             | Function                               |
|-------------------|----------------------------------------|
| TRIM_INIT_VAL_SEL | 0b - Mid-scale<br>1b - IFR             |
| 2                 | Reserved                               |
| —                 | Do not modify the value of this field. |
| 1                 | Reserved                               |
| 0                 | Reserved                               |
| —                 |                                        |

### 35.7.1.31 FIRC Oscillator Enable (CLK\_RECOVER\_IRC\_EN)

#### Offset

| Register           | Offset |
|--------------------|--------|
| CLK_RECOVER_IRC_EN | 144h   |

#### Function

Controls the USB-specific frequency trimming behavior for the on-chip FIRC module used to produce nominal 48 MHz clocks for USB crystal-less operation and other functions.

See the FIRC operation in the "Clock Distribution" section in the SCG chapter for more information.

#### Diagram



#### Fields

| Field | Function        |
|-------|-----------------|
| 7-2   | Reserved        |
| 1     | Fast IRC enable |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field  | Function                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IRC_EN | <p>Configures the frequency trimming logic for the FIRC module to generate clocks for crystal-less FS USB Device mode operation. You must initialize FIRCCSR[FIRCEN] and FIRCTCFG[TRIMSRC] for the SCG module to enable the FIRC module itself. Then this field and <a href="#">CLK_RECOVER_CTRL[CLOCK_RECOVER_EN]</a> must become 1 before using the crystal-less USB clock configuration.</p> <p>0b - Disable<br/>1b - Enable</p> |
| 0<br>— | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                            |

### 35.7.1.32 Clock Recovery Combined Interrupt Enable (CLK\_RECOVER\_INT\_EN)

#### Offset

| Register            | Offset |
|---------------------|--------|
| CLK_RECOVER_INT_E_N | 154h   |

#### Function

Enables or masks the individual interrupt flags, which are logically OR'ed together, to produce the combined interrupt indication at [USBTRC0\[USB\\_CLK\\_RECOVERY\\_INT\]](#) if you detect the indicated conditions in the USB clock recovery algorithm operation.

#### Diagram



#### Fields

| Field             | Function                                                                                                                                       |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-5<br>—          | Reserved                                                                                                                                       |
| 4<br>OVF_ERROR_EN | <p>Overflow error interrupt enable</p> <p>Determines whether the OVF_ERROR condition signal is used in generation of USB_CLK_RECOVERY_INT.</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                      |
|----------|---------------------------------------------------------------|
|          | 0b - The interrupt is masked<br>1b - The interrupt is enabled |
| 3-0<br>— | Reserved                                                      |

### 35.7.1.33 Clock Recovery Separated Interrupt Status (CLK\_RECOVER\_INT\_STATUS)

#### Offset

| Register                   | Offset |
|----------------------------|--------|
| CLK_RECOVER_INT_S<br>TATUS | 15Ch   |

#### Function

Contains flags for clock-recovery interrupts.

#### Diagram



#### Fields

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-5<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                     |
| 4<br>OVF_ERROR | <p>Overflow Error Interrupt Status Flag</p> <p>Indicates that the USB clock recovery algorithm detects that the frequency trim adjustment needed for the FIRC output clock is outside the available TRIM_FINE adjustment range for FIRC.</p> <p><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <p>0b - Interrupt did not occur</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                    |
|----------|-------------------------------------------------------------------------------------------------------------|
|          | <p>1b - Unmasked interrupt occurred<br/>When writing<br/>    0b - No effect<br/>    1b - Clear the flag</p> |
| 3-0<br>— | Reserved                                                                                                    |

# Chapter 36

## Low Power Inter-Integrated Circuit (LPI2C)

### 36.1 Chip-specific LPI2C information

Table 197. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | LPI2C          | <a href="#">LPI2C</a>               |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 36.1.1 Module instances

This device supports one instance of LPI2C: LPI2C0.

### 36.2 Overview

LPI2C supports an efficient interface to an I<sup>2</sup>C bus as a controller and target:

- Implements logic support for Standard, Fast, Fast+, HS-mode (target only) and Ultra-Fast modes of operation
- Uses little CPU overhead, with DMA offloading of FIFO register accesses

LPI2C also complies with the System Management Bus (SMBus) Specification, version 3. The SMBus is a single-ended simple two-wire bus, which is typically used for low-bandwidth communications.

The Inter-Integrated Circuit (I<sup>2</sup>C) serial bus is multi-controller, multi-target, packet-switched, and single-ended, and is often used to attach microcontroller ICs to lower-speed peripheral ICs.

#### NOTE

Terminology in this chapter has been updated to align with I<sup>2</sup>C-bus specification, Rev. 7.0, as shown in [Table 198](#).

Table 198. Updated terms

| Updated term | Deprecated term |
|--------------|-----------------|
| Controller   | Master          |
| Target       | Slave           |

### 36.2.1 Block diagram



Figure 159. Block diagram

### 36.2.2 Features

LPI2C supports:

- Standard, Fast, Fast+ and Ultra Fast modes
- HS mode in target mode
- Multicontroller, including synchronization and arbitration, means that any number of controller nodes can be present. Also, controller and target roles can be changed between messages (after a Stop signal is sent).
- Clock stretching. Used on the SCL line, as an I2C flow control mechanism.
- Arbitration for when the system has more than one controller. When used on the SDA line, ensures that there is only one I2C transmitter at a time.
- General call, seven-bit addressing, and ten-bit addressing
- Software reset, Start byte, and device ID (also require software support)

The LPI2C controller supports:

- Command and transmit FIFO of 4 words (8-bit transmit data + 3-bit command)

- Receive FIFO of 4 words (8-bit receive data).
- Command FIFO waiting for an I2C idle bus before initiating a transfer
- Initiation of repeated Start and Stop conditions and one or more controller-receiver transfers by command FIFO
- Stop condition generation from command FIFO, or automatic generation of Stop condition when the transmit FIFO is empty
- Host request input to control the start time of an I2C bus transfer
- Interrupt generation on data match and unwanted data rejection, via flexible receive data match
- Flags and optional interrupt signals at repeated Start condition, Stop condition, loss of arbitration, unexpected NACK, and command word errors
- Configurable bus idle timeout and pin-stuck-low timeout

The LPI2C target supports:

- Separate I2C target registers to minimize software overhead because of controller or target switching
- 7-bit or 10-bit addressing, address range, SMBus alert, and general call address.
- Transmit data register that supports interrupt or DMA requests
- Receive data register that supports interrupt or DMA requests
- Software-controllable ACK or NACK, with optional clock stretching on ACK or NACK field
- Configurable clock stretching, to avoid transmit-FIFO-underrun and receive-FIFO-overrun errors
- Flags and optional interrupt at end of packet, Stop condition, or bit error detection

## 36.3 Functional description

### 36.3.1 Controller mode

The LPI2C controller logic operates independently from the target logic to perform all controller-mode transfers on the I2C bus.

#### 36.3.1.1 Transmit and Command FIFO commands

The transmit FIFO stores command data to initiate various I2C operations. The following operations can be initiated through commands in the transmit FIFO:

- Start or repeated Start condition with address byte, expecting ACK or NACK.
- Transmit data. This operation is the default for zero-extended-byte writes to the transmit FIFO.
- Receive 1-256 bytes of data. You can configure this operation to discard received data and not to store it in the receive FIFO.
- Stop condition. You can configure this operation to send a Stop condition when the transmit FIFO is empty.

Multiple transmit and receive commands can be inserted between the Start and Stop conditions. To comply with the I2C specification, transmit and receive commands must not be interleaved. The receive data command and the receive data and discard commands can be interleaved. This interleaving ensures that only the desired received data is stored in the receive FIFO (or compared with the data match logic).

The LPI2C controller automatically transmits a NACK on the last byte of a receive data command. It transmits the NACK unless the next command in the FIFO is also a receive data command. If the transmit FIFO is empty when a receive data command completes, a NACK is also automatically transmitted.

The LPI2C controller supports 10-bit addressing via a (repeated) Start condition, followed by a transmit data byte containing the second address byte, followed by any number of data bytes with the controller transmit data.

A Start or repeated Start condition expecting a NACK (for example, HS mode controller code) must be followed by a Stop or (repeated) Start condition.

### 36.3.1.2 Controller operations

When LPI2C is enabled, it monitors the I2C bus to detect when the I2C is idle ([MSR\[BBF\]](#)). If either SCL or SDA are low, the I2C bus is no longer considered idle. The bus becomes idle if a Stop condition is detected or if a bus idle timeout is detected (as configured by [MCFGR2\[BUSIDLE\]](#)). After the bus is idle, if the transmit FIFO is not empty and the host request is asserted or disabled, the LPI2C controller initiates a transfer on the bus. This transfer involves the following steps:

1. Wait the bus idle time equal to ([MCCR0\[CLKLO\]](#) + 1) multiplied by the prescaler ([MCFGR1\[PSCALE\]](#)).
2. Transmit a Start condition and address byte using the timing configuration in [Controller Clock Configuration 0 \(MCCR0\)](#). If an HS mode transfer is configured, the timing configuration from [Controller Clock Configuration 1 \(MCCR1\)](#) is used instead.
3. Perform controller transmit or controller receive transfers, as configured by the transmit FIFO.
4. Transmit NACK on the last byte of a controller receive transfer. This action is performed unless the next command in the transmit FIFO is also a receive data command and the transmit FIFO is not empty.
5. Transmit a repeated Start or Stop condition as configured by the transmit FIFO or [MCFGR1\[AUTOSTOP\]](#). A repeated Start can change which timing configuration register is used.

When [MCFGR0\[RELAX\]](#) is 1, the LPI2C controller does not wait for the I2C bus to be idle before starting a transfer. It also relaxes some restrictions on the order of FIFO commands. For example, it allows a Stop command when it is idle to generate a Start condition, followed by one SCL clock pulse, and then a Stop condition.

When the LPI2C controller is disabled, LPI2C continues emptying the transmit FIFO until a Stop condition is transmitted. (The controller could be disabled due to [MCR\[MEN\]](#) being 0, or automatically due to mode entry.) However, LPI2C no longer stalls the I2C bus by waiting for the transmit or receive FIFO. After the transmit FIFO is empty, LPI2C generates a Stop condition automatically.

The LPI2C controller can stall the I2C bus under certain conditions. This stalling results in SCL pulled low continuously on the first bit of a byte, until these conditions change:

- The LPI2C controller is enabled and busy, the transmit FIFO is empty, and [MCFGR1\[AUTOSTOP\]](#) is 0. The LPI2C controller continues to stall the bus until the transmit FIFO is loaded with more data.
- The LPI2C controller is enabled and receiving data, receive data is not being discarded (due to command or receive data match), and the receive FIFO is full. The LPI2C controller continues to stall the I2C bus until the receive FIFO is emptied.

The LPI2C controller aborts the existing transfer when [MCFGR0\[ABORT\]](#) becomes 1. This action causes the LPI2C controller to complete the existing word and then transmit a Stop condition. If the receive FIFO is full when the receive operation is aborted, the last received data is discarded. A new transfer does not start while [MCFGR0\[ABORT\]](#) is 1.

### 36.3.1.3 Receive FIFO and data matching

The receive FIFO stores receive data during controller-receiver transfers. You can configure the LPI2C controller to discard received data instead of storing it in the receive FIFO. This option is configured via the command word in the transmit FIFO.

Received data supports a receive data match function that can match received data against one of two bytes, or against a masked data byte. You can configure the data match function to compare only the first one or two data words received since the last (repeated) Start condition. Received data that is already discarded due to the command word cannot cause a data match. It delays the match on the first data word received until after the discarded data is received.

You can configure the receiver match function to discard all received data until a data match is detected, using [MCFGR0\[RDMO\]](#). Following a data match, write 0 to [MCFGR0\[RDMO\]](#) before writing 0 to [MSR\[DMF\]](#) to allow all subsequent data to be received.

### 36.3.1.4 Timing parameters

The LPI2C controller can configure the following timing parameters. Parameters are configured separately for HS mode ([Controller Clock Configuration 1 \(MCCR1\)](#)) and other modes ([Controller Clock Configuration 0 \(MCCR0\)](#)). This separation allows the HS mode controller code to be sent using regular timing parameters. Then it allows a switch to HS mode timing (following a repeated Start) until the next STOP condition.

Configure the LPI2C controller timing parameters, measured in LPI2C functional clock cycles, as shown in [Table 199](#). You must configure these parameters to meet the I2C timing specification for the required mode.

**Table 199. Timing parameters**

| I2C specification timing parameter                          | I2C specification timing symbol | LPI2C timing parameter (in LPI2C functional clock cycles) |
|-------------------------------------------------------------|---------------------------------|-----------------------------------------------------------|
| SCL clock period                                            | tSCL                            | (CLKHI + CLKLO + 2 + SCL_LATENCY) × (2 ^ PRESCALE)        |
| Hold time (repeated) Start condition                        | tHD:STA                         | (SETHOLD +1) × (2 ^ PRESCALE)                             |
| Low period of the SCL clock                                 | tLOW                            | (CLKLO + 1) × (2 ^ PRESCALE)                              |
| High period of the SCL clock                                | tHIGH                           | (CLKHI + 1 + SCL_LATENCY) × (2 ^ PRESCALE)                |
| Setup time for a repeated Start condition or Stop condition | tSU:STA, tSU:STO                | (SETHOLD + 1 + SCL_LATENCY) × (2 ^ PRESCALE)              |
| Data hold time                                              | tHD:DAT                         | (DATAVD + 1) × (2 ^ PRESCALE)                             |
| Data setup time                                             | tSU:DAT                         | (SDA_LATENCY + 1) × (2 ^ PRESCALE)                        |
| Bus free time between a Stop and Start condition            | tBUF                            | (CLKLO + 1 + SDA_LATENCY) × (2 ^ PRESCALE)                |
| Data valid time, data valid acknowledge time                | tVD:DAT, tVD:ACK                | (DATAVD + 1) × (2 ^ PRESCALE)                             |

[Table 200](#) defines the latency parameters. These parameters assume that the risetime is less than one LPI2C functional clock cycle. The risetime depends on a number of factors, including the I/O propagation delay, the I2C bus loading, and the external pullup resistor sizing. A larger risetime increases the number of cycles that the signal takes to propagate through the synchronizer (and glitch filter), which increases the latency.

**Table 200. Synchronization latency**

| Timing parameter | Timing definition                                         |
|------------------|-----------------------------------------------------------|
| SCL_LATENCY      | ROUNDDOWN ((2 + FILTSCL + SCL_RISETIME) ÷ (2 ^ PRESCALE)) |
| SDA_LATENCY      | ROUNDDOWN ((2 + FILTSDA + SDA_RISETIME) ÷ (2 ^ PRESCALE)) |

The following timing restrictions must be enforced to avoid unexpected Start or Stop conditions on the I2C bus. These restrictions also avoid unexpected Start or Stop conditions detected by the LPI2C controller. The timing restrictions can be summarized as "SDA cannot change when SCL is high outside a transmitted (repeated) Start or Stop condition."

**Table 201. LPI2C timing parameter restrictions**

| Timing parameter | Minimum | Maximum | Comment                                                                      |
|------------------|---------|---------|------------------------------------------------------------------------------|
| CLKLO            | 03h     | —       | CLKLO × (2 ^ PRESCALE) > SCL_LATENCY                                         |
| CLKHI            | 01h     | —       | Configure CLKHI to meet the duty cycle requirements in the I2C specification |
| SETHOLD          | 02h     | —       | SETHOLD × (2 ^ PRESCALE) > SDA_LATENCY                                       |

*Table continues on the next page...*

Table 201. LPI2C timing parameter restrictions (continued)

| Timing parameter | Minimum                   | Maximum                      | Comment                                                                                             |
|------------------|---------------------------|------------------------------|-----------------------------------------------------------------------------------------------------|
| DATAVD           | 01h                       | CLKLO – SDA_LATENCY – 1      | Configure DATAVD to meet the data hold requirement in the I2C specification                         |
| FILTSCL          | 00h                       | [CLKLO × (2 ^ PRESCALE)] – 3 | FILTSCL and FILTSDA are the only parameters not multiplied by (2 ^ PRESCALE)                        |
| FILTSDA          | FILTSCL                   | [CLKLO × (2 ^ PRESCALE)] – 3 | Configuring FILTSDA greater than FILTSCL can delay the SDA input to compensate for board level skew |
| BUSIDLE          | (CLKLO + SETHOLD + 2) × 2 | —                            | Must also be greater than (CLKHI + 1)                                                               |

See the UM10204, *I2C-bus specification and user manual*.

See [Application information](#) for example LPI2C timing configurations.

### 36.3.1.5 Error conditions

The LPI2C controller monitors errors while it is active. The following conditions generate an error flag and block a new Start condition from being sent, until the flag is cleared by software:

- A Start or Stop condition is detected and is not generated by the LPI2C controller ([MSR\[ALF\]](#) becomes 1).
- Transmitting data on SDA and different values are received ([MSR\[ALF\]](#) becomes 1). LPI2C controller stops driving SDA immediately, but continues to drive SCL for the remainder of the byte.
- NACK is detected when transmitting data, and [MCFGR1\[IGNACK\]](#) is 0 ([MSR\[NDF\]](#) becomes 1).
- NACK is detected and is expecting ACK for the address byte, and [MCFGR1\[IGNACK\]](#) is 0 ([MSR\[NDF\]](#) becomes 1).
- ACK is detected and is expecting NACK for the address byte, and [MCFGR1\[IGNACK\]](#) is 0 ([MSR\[NDF\]](#) becomes 1).
- Transmit FIFO is requesting to transmit or receive data without a Start condition ([MSR\[FEF\]](#) becomes 1). This restriction is ignored when [MCFGR0\[RELAX\]](#) is 1.
- SCL (or SDA if [MCFGR1\[TIMECFG\]](#) is 1) is low for ([MCFGR2\[TIMELOW\]](#) × 256) prescaler cycles without a pin transition ([MSR\[PLTF\]](#) becomes 1).

You must respond to [MSR\[PLTF\]](#) to terminate the existing command. You can terminate the command cleanly by writing 0 to [MCR\[MEN\]](#), or you can terminate it abruptly by writing 1 to [MCR\[RST\]](#).

You can use [MCFGR0\[RELAX\]](#) to attempt to recover a target with SDA stuck low. If [MCFGR0\[RELAX\]](#) is 1, the LPI2C controller does not wait for the I2C bus to be idle before starting a transfer. Initiating a Start command with address FFh, then the Stop condition, should generate sufficient SCL clock edges to cause the target to release SDA.

You can use [MCFGR2\[BUSIDLE\]](#) to force the I2C bus to be considered idle when SCL and SDA remain high for (BUSIDLE + 1) prescaler cycles. The bus is considered idle when the LPI2C controller is first enabled. When BUSIDLE is configured greater than zero, then SCL or SDA must be high for (BUSIDLE + 1) prescaler cycles before the I2C bus is considered idle.

### 36.3.1.6 Pin configuration

| Configuration               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Open-drain support          | The LPI2C controller defaults to open-drain configuration of the SDA and SCL pins. Support for true open drain depends on the specific device, and requires the pins where LPI2C pins are muxed to support true open drain.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| HS mode support             | Support for HS mode depends on the specific device. This mode requires the SCL pin to support the current source pullup required in the I2C specification.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Ultra-Fast mode support     | The LPI2C controller supports the output-only push-pull function required for I2C Ultra-Fast mode using the SDA and SCL pins. Support for Ultra-Fast mode also requires <a href="#">MCFGR1[IGNACK]</a> to be 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Push-pull two-wire support  | A push-pull two-wire configuration is available to the LPI2C controller. If LPI2C is the only controller and all I2C pins on the bus are at the same voltage, this configuration may support a partial HS mode. A partial HS mode, not a full HS mode, because this configuration actively drives high rather than enabling a current service pull-up. This configuration sets the SCL pin as push-pull for every clock except the ninth clock pulse, to allow HS-mode-compatible targets to perform clock stretching. In this mode, the SDA pin is tristated for controller-receive data bits and controller-transmit ACK/NACK bits, and is configured as push-pull at other times. To avoid the risk of contention when SDA is push-pull, configure the pin for open-drain operation, as part of the device-specific configuration. |
| Push-pull four-wire support | The push-pull four-wire configuration separates the SCL input data and output data into separate pins. It also separates the SDA input data and output data into separate pins. The SCL/SDA pins are used for input data; the SCLS/SDAS pins are used for output data, with configurable polarity. This configuration simplifies external connections when connecting the LPI2C to the I2C bus through external level shifters or discrete components. When using this four-wire configuration, the LPI2C controller logic and LPI2C target logic cannot connect to separate I2C buses.                                                                                                                                                                                                                                               |

### 36.3.2 Target mode

To perform all target mode transfers on the I2C bus, the LPI2C target logic operates independently from the LPI2C controller logic.

#### 36.3.2.1 Address matching

You can configure the LPI2C target:

- To match one of two addresses, using either 7-bit or 10-bit addressing modes for each address.
- To match a range of addresses in either 7-bit or 10-bit addressing modes.
- To match the general call address and generate appropriate flags.
- To match the SMBus alert address and generate appropriate flags.
- To detect the HS mode controller code address, and to disable the digital filters and output valid delay time until the next Stop condition is detected.

After a valid address is matched, the LPI2C target automatically performs target-transmit or target-receive transfers until:

- A NACK is detected (unless [SCFGR1\[IGNACK\]](#) becomes 1).
- A bit error is detected (the LPI2C target is driving SDA, but a different value is sampled).
- A (repeated) Start or Stop condition is detected.

When [SCFGR1\[RXALL\]](#) is 1, the LPI2C target receives all addresses and data on the I2C bus. Unless the address is matched, it never drives the SDA pin. Configure the LPI2C target to match only on 7-bit address mode when this feature is enabled. Software can support 10-bit address mode. This option is intended for debugging the contents of an I2C transfer between another controller

and target. Likewise, [SCFGR1\[SDCFG\]](#) and [SCFGR1\[RSCFG\]](#) configure the Stop or repeated Start flags to assert on all Stop or repeated Start conditions, even when there is no address match.

### 36.3.2.2 Transmit and receive data

[Target Transmit Data \(STDR\)](#) and [Target Receive Data \(SRDR\)](#) are double-buffered and only update during a target-transmit and target-receive transfer, respectively.

You can configure the target address that was received to be read from SRDR (for example, when using DMA to transfer data) or from [Target Address Status \(SASR\)](#).

You can configure STDR to request data only after a target-transmit transfer is detected. You can also configure it to request new data whenever STDR is empty.

Write to STDR only when [SSR\[TDF\]](#) is set.

Read SRDR only when [SSR\[RDF\]](#) is set, or when [SSR\[AVF\]](#) is set and [SCFGR1\[RXCFG\]](#) = 1.

Read SASR only when [SSR\[AVF\]](#) is set.

### 36.3.2.3 Read request

The LPI2C target generates a read request when the I2C bus is idle and you write 1 to [SCFGR0\[RDREQ\]](#). This occurrence causes the LPI2C target to pull the SDA pin low until either the first SCL falling edge or SCFGR0[RDREQ] becomes 0. Following the next Stop condition or a software timeout, you can proceed as follows:

- If the LPI2C target is accessed at the correct address, the read request is acknowledged, and you must write 0 to SCFGR0[RDREQ].
- If [SCFGR0\[RDACK\]](#) is 1, the read request is acknowledged by a Start followed by one SCL pulse followed by a STOP condition. You must write 0 to SCFGR0[RDREQ].
- If neither of the first two cases occurred, the read request is not acknowledged. You must write 0 and then 1 to SCFGR0[RDREQ] after an appropriate delay, provided the I2C bus is idle.
- If a software timeout occurs, the read request is not acknowledged, and you should write 0 to SCFGR0[RDREQ]. Another request can be generated after an appropriate delay.

Writing to SCFGR0[RDREQ] when the I2C bus is busy results in a logic 0 being written. Write 1 to SCFGR0[RDREQ], then confirm that the register is written to correctly. If the register does not update correctly, the I2C bus is no longer idle and the read request must be attempted later.

### 36.3.2.4 Clock stretching

The LPI2C target supports many configurable options for clock stretching. You can configure these conditions to perform clock stretching:

- [SSR\[AVF\]](#) is set during the ninth clock pulse of the address byte.
- [SSR\[TDF\]](#) is set during the ninth clock pulse of a target-transmit transfer.
- [SSR\[RDF\]](#) is set during the ninth clock pulse of a target-receive transfer.
- [SSR\[TAF\]](#) is set during the eighth clock pulse of an address byte or a target-receive transfer. In HS mode, this option is disabled.
- Clock stretching can be extended for a number of cycles equal to the value of [SCFGR2\[CLKHOLD\]](#) cycles. This stretching allows additional setup time to sample the SDA pin externally. In HS mode, this option is disabled.

When clock stretching is enabled, clock stretching extends for one peripheral bus clock cycle after SDA updates, unless extended by the SCFGR2[CLKHOLD] configuration.

### 36.3.2.5 Timing parameters

The LPI2C target can configure the following timing parameters:

- SDA data valid time from SCL negation to SDA update
- SCL hold time when clock stretching is enabled to increase setup time when sampling SDA externally
- SCL glitch filter time
- SDA glitch filter time

These parameters are disabled when [SCR\[FILTEN\]](#) is 0, when [SCR\[FILTDZ\]](#) is 1 in Doze mode, and when LPI2C target detects HS mode. When disabled, the LPI2C target is clocked directly from the I2C bus. In this case, the target may not satisfy all timing requirements of the I2C specification (such as SDA minimum hold time in Standard/Fast mode).

The LPI2C target places the following restrictions on the timing parameters:

- You must configure [SCFGR2\[FILTSDA\]](#) to be greater than or equal to [SCFGR2\[FILTSL\]](#) (unless compensating for board level skew between SDA and SCL).
- You must configure [SCFGR2\[DATAVD\]](#) to be less than the minimum SCL low period.

### 36.3.2.6 Error conditions

The LPI2C target can flag the following error conditions:

- [SSR\[BEF\]](#) is set when the LPI2C target is driving SDA but it samples a different value than what is expected.
- [SSR\[FEF\]](#) is set due to a transmit data underrun or a receive data overrun. To eliminate the possibility of underrun and overrun, enable clock stretching. When [SCFGR1\[RXNACK\]](#) is 1, the LPI2C target generates a NACK on a receive data overrun.
- [SSR\[FEF\]](#) is also set due to an address overrun, but only when [SCFGR1\[RXCFG\]](#) is 1. To eliminate the possibility of overrun, enable clock stretching. When [SCFGR1\[RXNACK\]](#) is 1, the LPI2C target generates a NACK on an address overrun regardless of the value of [SCFGR1\[RXCFG\]](#).

The LPI2C target does not implement a timeout due to SCL or SDA being stuck low. If this detection is required, use the LPI2C controller logic so you can reset the LPI2C target when this condition is detected.

### 36.3.3 Low-power modes

LPI2C remains functional during low-power modes, if [MCR\[DOZEN\]](#) = 0 and LPI2C uses an external or internal clock source that remains enabled. LPI2C can generate an interrupt or DMA request to cause a wake-up from low-power modes.

You can configure LPI2C to be disabled in low-power modes when [MCR\[DOZEN\]](#) = 1. In this case, LPI2C waits for the current transfer to complete any pending operation.

#### NOTE

See the chip-specific information for low-power modes available on your chip.

### 36.3.4 Debug mode

Table 202. Debug mode

| Mode  | LPI2C operation                                                          |
|-------|--------------------------------------------------------------------------|
| Debug | If <a href="#">MCR[DBGEN]</a> = 1, can continue operating in Debug mode. |

### 36.3.5 Peripheral triggers

The connection of the LPI2C peripheral triggers to other peripherals depends upon the specific device being used.

**Table 203. LPI2C triggers**

| Trigger                   | Description                                                                                                                                                                                                                                                                                                                                                                        |
|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Controller output trigger | Generates an output trigger that can be connected to other peripherals on the device. The controller output trigger asserts on either a repeated Start or a Stop condition. The trigger remains asserted for one cycle of the LPI2C functional clock divided by <a href="#">MCFGR1[PRESCALE]</a> .                                                                                 |
| Target output trigger     | Generates an output trigger that can be connected to other peripherals on the device. The target output trigger asserts on either a repeated Start or a Stop condition that occurs after a target address match. The target output trigger remains asserted until the next target SCL pin negation.                                                                                |
| Input trigger             | To control the start of a LPI2C bus transfer, the LPI2C input trigger can be selected instead of the HREQ input. The input trigger is synchronized. To be detected, the input trigger must assert for at least two cycles of the LPI2C functional clock divided by the value of MCFGR1[PRESCALE]. When LPI2C is busy, the HREQ input (and therefore the input trigger) is ignored. |

### 36.3.6 Clocking

**Table 204. LPI2C clocks**

| Clock                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LPI2C functional clock | The LPI2C functional clock is asynchronous to the bus clock. It can remain enabled in low-power modes to support I2C bus transfers by the LPI2C controller. The functional clock is also used by the LPI2C target to support digital filter and data hold time configurations. The LPI2C controller divides the functional clock by a prescaler ( <a href="#">MCFGR1[PRESCALE]</a> ) and the resulting frequency must be at least eight times faster than the I2C bus bandwidth. |
| External clock         | The LPI2C target logic is clocked directly from the external pins. These pins are SCL and SDA, or SCLS and SDAS if the controller and target are implemented on separate pins). This clocking allows the LPI2C target to remain operational, even when the LPI2C functional clock is disabled.                                                                                                                                                                                   |
| Bus clock              | The bus clock is only used for bus accesses to the control and configuration registers. The bus clock frequency must be sufficient to support the data bandwidth requirements of the LPI2C controller and target registers.                                                                                                                                                                                                                                                      |

For chip-specific clocking information, see the Clocking chapter.

### 36.3.7 Reset

**Table 205. LPI2C resets**

| Reset          | Description                                                                                                                                                                                                                             |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Chip reset     | The logic and registers for the LPI2C controller and target are reset to their default states after a chip reset.                                                                                                                       |
| Software reset | The LPI2C controller implements a software reset field in its control register. <a href="#">MCR[RST]</a> resets all controller logic and registers to their default states, except for <a href="#">Controller Control (MCR)</a> itself. |

*Table continues on the next page...*

Table 205. LPI2C resets (continued)

| Reset      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | The LPI2C target implements a software reset field in its control register. <a href="#">SCR[RST]</a> resets all target logic and registers to their default states, except for <a href="#">Target Control (SCR)</a> itself.                                                                                                                                                                                                                                    |
| FIFO reset | The LPI2C controller implements write-only control fields that reset the transmit FIFO ( <a href="#">MCR[RTF]</a> ) and receive FIFO ( <a href="#">MCR[RFF]</a> ). After a FIFO is reset, that FIFO is empty.<br>The LPI2C target implements write-only control fields that reset the transmit data register ( <a href="#">SCR[RTF]</a> ) and receive data register ( <a href="#">SCR[RFF]</a> ). After a data register is reset, that data register is empty. |

### 36.3.8 Interrupts and DMA requests

Depending on the configuration, interrupts and DMA requests can be combined:

- LPI2C controller and target interrupts
- LPI2C controller and target transmit DMA requests
- LPI2C controller and target receive DMA requests

#### 36.3.8.1 Controller mode

[Table 206](#) lists the Controller mode sources that can generate LPI2C controller interrupts and LPI2C controller transmit and receive DMA requests.

Table 206. Controller interrupts and DMA requests

| Status flag                                        | Description                                                                                                                                                                                                                         | Can generate |              |                    |
|----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|--------------------|
|                                                    |                                                                                                                                                                                                                                     | Interrupt?   | DMA request? | Low-power wake-up? |
| Transmit Data Flag ( <a href="#">MSR[TDF]</a> )    | Data can be written to transmit FIFO, as configured by <a href="#">MFCR[TXWATER]</a> .                                                                                                                                              | Y            | TX           | Y                  |
| Receive Data Flag ( <a href="#">MSR[RDF]</a> )     | Data can be read from the receive FIFO, as configured by <a href="#">MFCR[RXWATER]</a> .                                                                                                                                            | Y            | RX           | Y                  |
| End Packet Flag ( <a href="#">MSR[EPF]</a> )       | Controller has transmitted a repeated Start or Stop condition.                                                                                                                                                                      | Y            | N            | Y                  |
| Stop Detect Flag ( <a href="#">MSR[SDF]</a> )      | Controller has transmitted a Stop condition (and the LPI2C controller is idle, if <a href="#">MCFGR1[STOPCFG] = 1</a> ).                                                                                                            | Y            | N            | Y                  |
| NACK Detect Flag ( <a href="#">MSR[NDF]</a> )      | During an address byte, the controller expects an ACK but detects a NACK.<br>During an address byte, the controller expects a NACK but detects an ACK.<br>During a controller-transmitter data byte, the controller detects a NACK. | Y            | N            | Y                  |
| Arbitration Lost Flag ( <a href="#">MSR[ALF]</a> ) | The controller lost arbitration due to a Start or Stop condition detected at the wrong time, or the controller was transmitting data                                                                                                | Y            | N            | Y                  |

*Table continues on the next page...*

Table 206. Controller interrupts and DMA requests (continued)

| Status flag                                         | Description                                                                                                                                           | Can generate |              |                    |
|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|--------------------|
|                                                     |                                                                                                                                                       | Interrupt?   | DMA request? | Low-power wake-up? |
|                                                     | but received data different from the data that was transmitted.                                                                                       |              |              |                    |
| FIFO Error Flag<br><a href="#">(MSR[FEF])</a>       | The controller expects a Start condition in the command FIFO, but the next entry in the command FIFO is not a Start condition.                        | Y            | N            | Y                  |
| Pin Low Timeout Flag<br><a href="#">(MSR[PLTF])</a> | Pin low timeout is enabled and SCL (or SDA, if configured) is low for longer than the configured timeout.                                             | Y            | N            | Y                  |
| Data Match Flag<br><a href="#">(MSR[DMF])</a>       | The received data matches the configured data match, but the received data is not discarded due to a command FIFO entry.                              | Y            | N            | Y                  |
| Start Detect Flag<br><a href="#">(MSR[STF])</a>     | A Start condition is detected on the I2C bus (and the LPI2C controller is idle, if <a href="#">MCFGR1[STARTCFG] = 1</a> ).                            | Y            | N            | Y                  |
| Controller Busy Flag<br><a href="#">(MSR[MBF])</a>  | LPI2C controller is busy transmitting or receiving data.                                                                                              | N            | N            | N                  |
| Bus Busy Flag<br><a href="#">(MSR[BBF])</a>         | LPI2C controller is enabled and activity is detected on the I2C bus, but no Stop condition is detected and no bus idle timeout (if enabled) occurred. | N            | N            | N                  |

### 36.3.8.2 Target mode

Table 207 lists the target mode sources that can generate LPI2C target interrupts and LPI2C target transmit and receive DMA requests.

Table 207. Target interrupts and DMA requests

| Status flag                                       | Description                                                                  | Can generate |              |                    |
|---------------------------------------------------|------------------------------------------------------------------------------|--------------|--------------|--------------------|
|                                                   |                                                                              | Interrupt?   | DMA request? | Low-power wake-up? |
| Transmit Data Flag<br><a href="#">(SSR[TDF])</a>  | Data can be written to <a href="#">Target Transmit Data (STDR)</a> .         | Y            | TX           | Y                  |
| Receive Data Flag<br><a href="#">(SSR[RDF])</a>   | Data can be read from <a href="#">Target Receive Data (SRDR)</a> .           | Y            | RX           | Y                  |
| Address Valid Flag<br><a href="#">(SSR[AVF])</a>  | Address can be read from <a href="#">Target Address Status (SASR)</a> .      | Y            | RX           | Y                  |
| Transmit ACK Flag<br><a href="#">(SSR[TAF])</a>   | ACK or NACK can be written to <a href="#">Target Transmit ACK (STAR)</a> .   | Y            | N            | Y                  |
| Repeated Start Flag<br><a href="#">(SSR[RSF])</a> | Target has detected an address match followed by a repeated Start condition. | Y            | RX           | Y                  |

*Table continues on the next page...*

Table 207. Target interrupts and DMA requests (continued)

| Status flag                              | Description                                                                                                                                                                                                                                                       | Can generate |              |                    |
|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|--------------------|
|                                          |                                                                                                                                                                                                                                                                   | Interrupt?   | DMA request? | Low-power wake-up? |
| Stop Detect Flag<br>(SSR[SDF])           | Target has detected an address match followed by a Stop condition.                                                                                                                                                                                                | Y            | RX           | Y                  |
| Bit Error Flag<br>(SSR[BEF])             | Target was transmitting data, but received data is different from what was transmitted.                                                                                                                                                                           | Y            | N            | Y                  |
| FIFO Error Flag<br>(SSR[FEF])            | This flag is set by: <ul style="list-style-type: none"><li>• Transmit data underrun</li><li>• Receive data overrun</li><li>• Address status overrun when <a href="#">SCFGR1[RXCFG] = 1</a></li></ul> This flag can only be set when clock stretching is disabled. | Y            | N            | Y                  |
| Address Match 0 Flag<br>(SSR[AM0F])      | Target detected an address match <a href="#">SAMR[ADDR0]</a> .                                                                                                                                                                                                    | Y            | N            | N                  |
| Address Match 1 Flag<br>(SSR[AM1F])      | Target detected an address match with <a href="#">SAMR[ADDR1]</a> or using an address range.                                                                                                                                                                      | Y            | N            | N                  |
| General Call Flag<br>(SSR[GCF])          | Target detected an address match with the general call address.                                                                                                                                                                                                   | Y            | N            | N                  |
| SMBus Alert Response Flag<br>(SSR[SARF]) | Target detected an address match with the SMBus alert address.                                                                                                                                                                                                    | Y            | N            | N                  |
| Target Busy Flag<br>(SSR[SBF])           | LPI2C target is busy receiving an address byte or is transmitting or receiving data.                                                                                                                                                                              | N            | N            | N                  |
| Bus Busy Flag<br>(SSR[BBF])              | LPI2C target is enabled and a Start condition is detected on I2C bus, but no Stop condition detected.                                                                                                                                                             | N            | N            | N                  |

### 36.3.8.3 End-of-packet DMA transfer

End-of-packet functionality serves serial interfaces where the transfer size may not be known in advance and the data is pushed by an external device. Examples include UART receive, I2C Target mode, and SPI Target mode. End-of-packet processing is intended to ensure that data does not become stranded in either the receive FIFO or DMA receive buffer. Support for end-of-packet processing must be implemented in both the serial interfaces and DMA controller.

The condition that signals the end of packet differs for each serial interface but is processed by the serial peripheral and DMA in the same way. For example:

- UART end of packet is signaled by an idle line condition.
- I2C end of packet is signaled by Stop or repeated Start condition.
- SPI end of packet is signaled by PCS negation.

When the serial peripheral is configured to signal an end-of-packet condition to the DMA and the serial interface detects an end-of-packet condition, it asserts the DMA request for the receive FIFO regardless of the watermark configuration. For larger watermark configurations, this behavior ensures that the last few words of the transfer are first flushed from the receive FIFO.

The DMA then reads the contents of the receive FIFO, depending on the first word in the FIFO:

- If the receive FIFO is empty, the serial interface signals an end-of-packet condition to the DMA controller.
- If the receive FIFO is not empty, but the first word in the FIFO starts a new packet, data is not pulled from the receive FIFO. Also, the serial interface signals an end-of-packet condition to the DMA controller.
- If the receive FIFO is not empty, and the first word in the FIFO does not start a new packet, the DMA transfers data as normal.

Because the DMA may transfer multiple words per request, the end-of-packet condition persists until the DMA minor loop finishes and no additional data is pulled from the FIFO. The status flag that triggered the end-of-packet condition is cleared when the minor loop completes after the end of packet is signaled to the DMA controller.

When the DMA detects the end-of-packet condition, it writes all received words up to the end of packet into system memory. It also saves the destination address for the word after the last valid data. The DMA then terminates the channel as if the major loop completed, including final offsets and optional interrupts, channel linking, and scatter-gather. The final destination address can be saved to system memory or is available in the destination address register.

Because the DMA terminates the major loop, the receive FIFO is not serviced until the DMA is reconfigured. You can perform this reconfiguration through software or hardware (for example, channel linking or scatter-gather). Minimize this delay to avoid receiver FIFO overrun. Automatic DMA end-of-packet processing is not recommended when there are only a few words transferred between end-of-packet conditions. In this case, the DMA spends more time processing the end of packet than transferring the data. For example, to avoid an excessive number of idle conditions, increase the UART idle line length as needed.

## 36.4 External signals

Table 208. External signals

| Signal | Name                     | Two-wire scheme                                                                                                                                                                                                                                                                                                                 | Four-wire scheme                                                                                                                                               | Direction       |
|--------|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| SCL    | LPI2C clock line         | SCL                                                                                                                                                                                                                                                                                                                             | In Four-Wire mode, this pin is the SCL input pin.                                                                                                              | Input or output |
| SDA    | LPI2C data line          | SDA                                                                                                                                                                                                                                                                                                                             | In Four-Wire mode, this pin is the SDA input pin.                                                                                                              | Input or output |
| SCLS   | Secondary I2C clock line | Not used                                                                                                                                                                                                                                                                                                                        | In Four-Wire mode, this pin is the SCLS output pin. If LPI2C controller/target are configured to use separate pins, then this pin is the LPI2C target SCL pin. | Input or output |
| SDAS   | Secondary I2C data line  | Not used                                                                                                                                                                                                                                                                                                                        | In Four-Wire mode, this pin is the SDAS output pin. If LPI2C controller/target are configured to use separate pins, then this pin is the LPI2C target SDA pin. | Input or output |
| HREQ   | Host request             | When configured for controller (input), if host request is asserted and the I2C bus is idle, it initiates a transfer. When configured for target (output), it asserts while valid data is present in <a href="#">Target Transmit Data (STDR)</a> .<br>HREQ is an additional pin separate from the two-wire or four-wire scheme. |                                                                                                                                                                | Input or output |

Figure 160 shows the two-signal connection.

Figure 160. I<sup>2</sup>C two-wire serial bus

Figure 161 shows a possible four-signal connection.

Figure 161. I<sup>2</sup>C four-wire serial bus

### 36.5 Initialization

To initialize the LPI2C controller:

1. Configure [Controller Configuration 0 \(MCFGR0\)](#)–[Controller Configuration 3 \(MCFGR3\)](#) as required by the application.
2. Configure [Controller Clock Configuration 0 \(MCCR0\)](#) and [Controller Clock Configuration 1 \(MCCR1\)](#) to satisfy the timing requirements of the I2C mode supported by the application.
3. Enable controller interrupts and DMA requests as required by the application.
4. Enable the LPI2C controller by writing 1 to [MCR\[MEN\]](#).

To initialize the LPI2C target:

1. Configure [Target Address Match \(SAMR\)](#) with the I2C address of the target location on the I2C bus.
2. Configure [Target Configuration 0 \(SCFGR0\)](#) and [Target Configuration 1 \(SCFGR1\)](#) as required by the application.
3. Configure [Target Configuration 2 \(SCFGR2\)](#) to satisfy the timing requirements of the I2C mode supported by the application.
4. Enable target interrupts and DMA requests as required by the application.
5. Enable the LPI2C target by writing 1 to [SCR\[SEN\]](#).

## 36.6 Application information

Configure the I2C timing parameters to meet the requirements of the I2C specification. This configuration depends on the supported mode and LPI2C functional clock frequency. When switching between two modes using different clock configuration registers (for example, Fast mode and HS mode), [MCFGR1\[PRESCALE\]](#) must remain constant between the modes.

Table 209. Example timing configurations

| I2C mode | Clock frequency | Baud rate   | PRESCALE | FILTSCL / FILTSDA | SETHOLD | CLKLO | CLKHI | DATAVD |
|----------|-----------------|-------------|----------|-------------------|---------|-------|-------|--------|
| Standard | 8 MHz           | 100 kbit/s  | 0h       | 0h/0h             | 24h     | 28h   | 24h   | 02h    |
| Standard | 48 MHz          | 100 kbit/s  | 2h       | 1h/1h             | 37h     | 3Fh   | 37h   | 03h    |
| Standard | 60 MHz          | 100 kbit/s  | 2h       | 1h/1h             | 45h     | 50h   | 44h   | 04h    |
| Fast     | 8 MHz           | 400 kbit/s  | 0h       | 0h/0h             | 04h     | 0Bh   | 05h   | 02h    |
| Fast+    | 8 MHz           | 1 Mbit/s    | 0h       | 0h/0h             | 02h     | 03h   | 01h   | 01h    |
| Fast     | 48 MHz          | 400 kbit/s  | 0h       | 1h/1h             | 1Dh     | 3Eh   | 35h   | 0Fh    |
| Fast     | 48 MHz          | 400 kbit/s  | 2h       | 1h/1h             | 07h     | 11h   | 0Bh   | 03h    |
| Fast+    | 48 MHz          | 1 Mbit/s    | 2h       | 1h/1h             | 03h     | 06h   | 04h   | 04h    |
| HS       | 48 MHz          | 3.2 Mbit/s  | 0h       | 0h/0h             | 07h     | 08h   | 03h   | 01h    |
| Fast     | 60 MHz          | 400 kbit/s  | 1h       | 2h/2h             | 11h     | 28h   | 1Fh   | 08h    |
| Fast+    | 60 MHz          | 1 Mbit/s    | 1h       | 2h/2h             | 07h     | 0Fh   | 0Bh   | 01h    |
| HS       | 60 MHz          | 3.33 Mbit/s | 1h       | 0h/0h             | 04h     | 04h   | 02h   | 01h    |

## 36.7 Memory map and registers

### 36.7.1 LPI2C register descriptions

Writing to a read-only register or reading from a write-only register can cause bus errors. This module does not check whether programmed values in the registers are correct; you must ensure that valid programmed values are written to the registers.

#### 36.7.1.1 LPI2C memory map

LPI2C0 base address: 4009\_A000h

| Offset | Register                                            | Width<br>(In bits) | Access | Reset value |
|--------|-----------------------------------------------------|--------------------|--------|-------------|
| 0h     | <a href="#">Version ID (VERID)</a>                  | 32                 | R      | 0103_0003h  |
| 4h     | <a href="#">Parameter (PARAM)</a>                   | 32                 | R      | 0000_0202h  |
| 10h    | <a href="#">Controller Control (MCR)</a>            | 32                 | RW     | 0000_0000h  |
| 14h    | <a href="#">Controller Status (MSR)</a>             | 32                 | RW     | 0000_0001h  |
| 18h    | <a href="#">Controller Interrupt Enable (MIER)</a>  | 32                 | RW     | 0000_0000h  |
| 1Ch    | <a href="#">Controller DMA Enable (MDER)</a>        | 32                 | RW     | 0000_0000h  |
| 20h    | <a href="#">Controller Configuration 0 (MCFGR0)</a> | 32                 | RW     | 0000_0000h  |

Table continues on the next page...

*Table continued from the previous page...*

| Offset | Register                                   | Width<br>(In bits) | Access | Reset value |
|--------|--------------------------------------------|--------------------|--------|-------------|
| 24h    | Controller Configuration 1 (MCFGR1)        | 32                 | RW     | 0000_0000h  |
| 28h    | Controller Configuration 2 (MCFGR2)        | 32                 | RW     | 0000_0000h  |
| 2Ch    | Controller Configuration 3 (MCFGR3)        | 32                 | RW     | 0000_0000h  |
| 40h    | Controller Data Match (MDMR)               | 32                 | RW     | 0000_0000h  |
| 48h    | Controller Clock Configuration 0 (MCCR0)   | 32                 | RW     | 0000_0000h  |
| 50h    | Controller Clock Configuration 1 (MCCR1)   | 32                 | RW     | 0000_0000h  |
| 58h    | Controller FIFO Control (MFCR)             | 32                 | RW     | 0000_0000h  |
| 5Ch    | Controller FIFO Status (MFSR)              | 32                 | R      | 0000_0000h  |
| 60h    | Controller Transmit Data (MTDR)            | 32                 | W      | 0000_0000h  |
| 70h    | Controller Receive Data (MRDR)             | 32                 | R      | 0000_4000h  |
| 78h    | Controller Receive Data Read Only (MRDROR) | 32                 | R      | 0000_4000h  |
| 110h   | Target Control (SCR)                       | 32                 | RW     | 0000_0000h  |
| 114h   | Target Status (SSR)                        | 32                 | RW     | 0000_0000h  |
| 118h   | Target Interrupt Enable (SIER)             | 32                 | RW     | 0000_0000h  |
| 11Ch   | Target DMA Enable (SDER)                   | 32                 | RW     | 0000_0000h  |
| 120h   | Target Configuration 0 (SCFGR0)            | 32                 | RW     | 0000_0000h  |
| 124h   | Target Configuration 1 (SCFGR1)            | 32                 | RW     | 0000_0000h  |
| 128h   | Target Configuration 2 (SCFGR2)            | 32                 | RW     | 0000_0000h  |
| 140h   | Target Address Match (SAMR)                | 32                 | RW     | 0000_0000h  |
| 150h   | Target Address Status (SASR)               | 32                 | R      | 0000_4000h  |
| 154h   | Target Transmit ACK (STAR)                 | 32                 | RW     | 0000_0000h  |
| 160h   | Target Transmit Data (STDR)                | 32                 | W      | 0000_0000h  |
| 170h   | Target Receive Data (SRDR)                 | 32                 | R      | 0000_4000h  |
| 178h   | Target Receive Data Read Only (SRDROR)     | 32                 | R      | 0000_4000h  |

### 36.7.1.2 Version ID (VERID)

#### Offset

| Register | Offset |
|----------|--------|
| VERID    | 0h     |

**Function**

Contains version numbers for the module design and feature set.

**Diagram**

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

**Fields**

| Field   | Function                                                                                                                                                                            |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24   | Major Version Number                                                                                                                                                                |
| MAJOR   | Returns the major version number for the module design specification.                                                                                                               |
| 23-16   | Minor Version Number                                                                                                                                                                |
| MINOR   | Returns the minor version number for the module design specification.                                                                                                               |
| 15-0    | Feature Specification Number                                                                                                                                                        |
| FEATURE | Returns the feature set number.<br><br>0000_0000_0000_0010b - Controller only, with standard feature set<br>0000_0000_0000_0011b - Controller and target, with standard feature set |

**36.7.1.3 Parameter (PARAM)****Offset**

| Register | Offset |
|----------|--------|
| PARAM    | 4h     |

**Function**

Contains parameter values implemented in the module.

**Diagram**

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

**Fields**

| Field   | Function                                                                                 |
|---------|------------------------------------------------------------------------------------------|
| 31-16   | Reserved                                                                                 |
| —       |                                                                                          |
| 15-12   | Reserved                                                                                 |
| —       |                                                                                          |
| 11-8    | Controller Receive FIFO Size                                                             |
| MRXFIFO | Configures the number of words in the controller receive FIFO to $2^{\text{MRXFIFO}}$ .  |
| 7-4     | Reserved                                                                                 |
| —       |                                                                                          |
| 3-0     | Controller Transmit FIFO Size                                                            |
| MTXFIFO | Configures the number of words in the controller transmit FIFO to $2^{\text{MTXFIFO}}$ . |

**36.7.1.4 Controller Control (MCR)****Offset**

| Register | Offset |
|----------|--------|
| MCR      | 10h    |

**Function**

Contains resets, debug enable, and other controller control settings.

**Diagram**

| Bits  | 31 | 30 | 29 | 28 | 27  | 26  | 25 | 24 | 23 | 22 | 21        | 20        | 19  | 18  | 17 | 16 |
|-------|----|----|----|----|-----|-----|----|----|----|----|-----------|-----------|-----|-----|----|----|
| R     | 0  |    |    |    |     |     |    |    |    |    |           |           |     |     |    |    |
| W     |    |    |    |    |     |     |    |    |    |    |           |           |     |     |    |    |
| Reset | 0  | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  | 0  | 0         | 0         | 0   | 0   | 0  | 0  |
| Bits  | 15 | 14 | 13 | 12 | 11  | 10  | 9  | 8  | 7  | 6  | 5         | 4         | 3   | 2   | 1  | 0  |
| R     | 0  |    |    |    | 0   | 0   | 0  |    |    |    | DBGE<br>N | DOZE<br>N | RST | MEN |    |    |
| W     |    |    |    |    | RRF | RTF |    |    |    |    | 0         | 0         | 0   | 0   | 0  |    |
| Reset | 0  | 0  | 0  | 0  | 0   | 0   | 0  | 0  | 0  | 0  | 0         | 0         | 0   | 0   | 0  | 0  |

**Fields**

| Field | Function                                                                        |
|-------|---------------------------------------------------------------------------------|
| 31-10 | Reserved                                                                        |
| —     |                                                                                 |
| 9     | Reset Receive FIFO                                                              |
| RRF   | Resets the receive FIFO.<br><br>0b - No effect<br><br>1b - Reset receive FIFO   |
| 8     | Reset Transmit FIFO                                                             |
| RTF   | Resets the transmit FIFO.<br><br>0b - No effect<br><br>1b - Reset transmit FIFO |
| 7-4   | Reserved                                                                        |
| —     |                                                                                 |
| 3     | Debug Enable                                                                    |
| DBGEN | Enables the controller in Debug mode.<br><br>0b - Disable<br><br>1b - Enable    |
| 2     | Doze Mode Enable                                                                |
| DOZEN | Enables the controller in Doze mode.<br><br>0b - Enable<br><br>1b - Disable     |
| 1     | Software Reset                                                                  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                 |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RST      | <p>Resets all internal controller logic and registers except <a href="#">Controller Control (MCR)</a>.</p> <p>This field remains 1 (enabled) until you write 0 to it. The reset takes effect immediately and remains asserted until negated by software. There is no minimum delay required before clearing the software reset.</p> <p>0b - No effect<br/>1b - Reset</p> |
| 0<br>MEN | <p>Controller Enable</p> <p>Enables the controller logic.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                        |

### 36.7.1.5 Controller Status (MSR)

#### Offset

| Register | Offset |
|----------|--------|
| MSR      | 14h    |

#### Function

Contains status flags for transmit and receive data, for start and stop conditions, and for bus and controller busy or idle status.

#### Diagram

| Bits  | 31  | 30  | 29   | 28  | 27  | 26  | 25  | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16  |
|-------|-----|-----|------|-----|-----|-----|-----|-----|----|----|----|----|----|----|-----|-----|
| R     |     |     |      |     | 0   |     | BBF | MBF |    |    |    |    | 0  |    |     |     |
| W     |     |     |      |     |     |     |     |     |    |    |    |    |    |    |     |     |
| Reset | 0   | 0   | 0    | 0   | 0   | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   |
| Bits  | 15  | 14  | 13   | 12  | 11  | 10  | 9   | 8   | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0   |
| R     | STF | DMF | PLTF | FEF | ALF | NDF | SDF | EPF |    |    |    |    | 0  |    | RDF | TDF |
| W     | W1C | W1C | W1C  | W1C | W1C | W1C | W1C | W1C |    |    |    |    |    |    |     |     |
| Reset | 0   | 0   | 0    | 0   | 0   | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 1   |

#### Fields

| Field | Function |
|-------|----------|
| 31-26 | Reserved |
| —     |          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25<br>BBF  | Bus Busy Flag<br>Specifies whether the I2C bus is busy.<br>0b - Idle<br>1b - Busy                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 24<br>MBF  | Controller Busy Flag<br>Specifies whether the I2C controller is busy.<br>0b - Idle<br>1b - Busy                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 23-16<br>— | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15<br>STF  | Start Flag<br>Specifies whether a Start condition is detected on the bus when the bus is idle. When <a href="#">MCFGR1[STARTCFG]</a> is 0, this field becomes 1 only if the LPI2C controller is also idle. When <a href="#">MCFGR1[STARTCFG]</a> is 1, STF becomes 1 for any Start condition when the I2C bus is idle.<br><br><b>NOTE</b><br>This field behaves differently for register reads and writes.<br><br>When reading<br>0b - Start condition not detected<br>1b - Start condition detected<br>When writing<br>0b - No effect<br>1b - Clear the flag |
| 14<br>DMF  | Data Match Flag<br>Indicates whether the received data matches <a href="#">MDMR[MATCH0]</a> or <a href="#">MDMR[MATCH1]</a> (as configured by <a href="#">MCFGR1[MATCFG]</a> ). Received data discarded due to <a href="#">MTDR[CMD]</a> does not cause this flag to set.<br><br><b>NOTE</b><br>This field behaves differently for register reads and writes.<br><br>When reading<br>0b - Matching data not received<br>1b - Matching data received<br>When writing<br>0b - No effect<br>1b - Clear the flag                                                  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13<br>PLTF | <p>Pin Low Timeout Flag</p> <p>Indicates whether pin low timeout has occurred. Sets when the SCL or SDA input is low for more than the number of PINLOW cycles defined by <a href="#">MCFGR3[PINLOW]</a>, even when the LPI2C controller is idle.</p> <p>You must resolve the pin low condition via software. PLTF cannot be cleared as long as the pin low timeout continues. Before LPI2C can initiate a Start condition, you must clear this flag.</p> <p>See <a href="#">MCFGR1[TIMECFG]</a> for the SCL and/or SDA timeout settings.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - Pin low timeout did not occur</li> <li>1b - Pin low timeout occurred</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul> |
| 12<br>FEF  | <p>FIFO Error Flag</p> <p>Detects the LPI2C controller's attempt to send or receive data without first generating a (repeated) Start condition. This error can occur when the transmit FIFO underflows when <a href="#">MCFGR1[AUTOSTOP]</a> = 1. When this flag is set, the LPI2C controller sends a Stop condition (if busy). The controller does not initiate a new Start condition until the flag is cleared.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - No FIFO error</li> <li>1b - FIFO error</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul>                                                                                                                                                       |
| 11<br>ALF  | <p>Arbitration Lost Flag</p> <p>Indicates whether arbitration is lost. Either of these conditions sets this flag:</p> <ul style="list-style-type: none"> <li>• The LPI2C controller transmits a logic 1 and detects a logic 0 on the I<sup>2</sup>C bus.</li> <li>• The LPI2C controller detects a Start or Stop condition when the LPI2C controller is transmitting data.</li> </ul> <p>When ALF is set, the LPI2C controller releases the I<sup>2</sup>C bus (goes idle), and the LPI2C controller does not initiate a new Start condition until the ALF is cleared.</p>                                                                                                                                                                                                                                                                                                                           |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | <p style="text-align: center;"><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - Controller did not lose arbitration</li> <li>1b - Controller lost arbitration</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 10<br>NDF | <p>NACK Detect Flag</p> <p>Indicates whether an unexpected NACK has been detected. This flag is set when the LPI2C controller detects a NACK it was not expecting when transmitting an address or data. When set, the controller does not initiate a new Start condition until this flag is cleared. If a NACK is expected for a given address (as configured by the command word), this flag is set if a NACK is not generated.</p> <p>When this flag is set, the LPI2C controller automatically transmits a Stop condition if <a href="#">MCFG1[AUTOSTOP]</a> = 1, or if the transmit FIFO is not empty.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - No unexpected NACK detected</li> <li>1b - Unexpected NACK detected</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul> |
| 9<br>SDF  | <p>Stop Detect Flag</p> <p>Indicates whether the LPI2C controller has generated a Stop condition. When <a href="#">MCFG1[STOPCFG]</a> = 0, this flag is set for any Stop condition. When <a href="#">MCFG1[STOPCFG]</a> = 1, this flag is set only when the LPI2C controller is also idle (transmit FIFO is empty).</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - No Stop condition generated</li> <li>1b - Stop condition generated</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> </ul>                                                                                                                                                                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 1b - Clear the flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 8<br>EPF | <p>End Packet Flag</p> <p>Indicates whether the LPI2C controller has generated a repeated Start condition or a Stop condition. When the controller first generates a Start condition, this flag is not set.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - No Stop or repeated Start generated</li> <li>1b - Stop or repeated Start generated</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul> |
| 7-2<br>— | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1<br>RDF | <p>Receive Data Flag</p> <p>Indicates whether the receive data is ready. This flag is set when the number of words in the receive FIFO is greater than <a href="#">MFCR[RXWATER]</a>.</p> <ul style="list-style-type: none"> <li>0b - Receive data not ready</li> <li>1b - Receive data ready</li> </ul>                                                                                                                                                                                                                                                                                                            |
| 0<br>TDF | <p>Transmit Data Flag</p> <p>Indicates whether transmit data is requested. This flag is set when the number of words in the transmit FIFO is equal or less than <a href="#">MFCR[TXWATER]</a>.</p> <ul style="list-style-type: none"> <li>0b - Transmit data not requested</li> <li>1b - Transmit data requested</li> </ul>                                                                                                                                                                                                                                                                                         |

### 36.7.1.6 Controller Interrupt Enable (MIER)

#### Offset

| Register | Offset |
|----------|--------|
| MIER     | 18h    |

#### Function

Contains enables for:

- Transmit and receive data interrupts

- Start, Stop, and NACK detection interrupts
- DMA interrupts

### Diagram

| Bits  | 31   | 30   | 29    | 28   | 27   | 26   | 25   | 24   | 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16   |
|-------|------|------|-------|------|------|------|------|------|----|----|----|----|----|----|------|------|
| R     |      |      |       |      |      |      |      |      | 0  |    |    |    |    |    |      |      |
| W     |      |      |       |      |      |      |      |      |    |    |    |    |    |    |      |      |
| Reset | 0    | 0    | 0     | 0    | 0    | 0    | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    |
| Bits  | 15   | 14   | 13    | 12   | 11   | 10   | 9    | 8    | 7  | 6  | 5  | 4  | 3  | 2  | 1    | 0    |
| R     | STIE | DMIE | PLTIE | FEIE | ALIE | NDIE | SDIE | EPIE |    |    |    |    | 0  |    | RDIE | TDIE |
| W     | 0    | 0    | 0     | 0    | 0    | 0    | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    |
| Reset | 0    | 0    | 0     | 0    | 0    | 0    | 0    | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    |

### Fields

| Field       | Function                                                                                                  |
|-------------|-----------------------------------------------------------------------------------------------------------|
| 31-16<br>—  | Reserved                                                                                                  |
| 15<br>STIE  | Start Interrupt Enable<br>Enables interrupt for Start condition.<br>0b - Disable<br>1b - Enable           |
| 14<br>DMIE  | Data Match Interrupt Enable<br>Enables interrupt for data match.<br>0b - Disable<br>1b - Enable           |
| 13<br>PLTIE | Pin Low Timeout Interrupt Enable<br>Enables interrupt for pin-low timeout.<br>0b - Disable<br>1b - Enable |
| 12<br>FEIE  | FIFO Error Interrupt Enable<br>Enables interrupt for FIFO error.<br>0b - Disable<br>1b - Enable           |
| 11          | Arbitration Lost Interrupt Enable                                                                         |

Table continues on the next page...

*Table continued from the previous page...*

| Field      | Function                                                                                              |
|------------|-------------------------------------------------------------------------------------------------------|
| ALIE       | Enables interrupt for arbitration lost.<br>0b - Disable<br>1b - Enable                                |
| 10<br>NDIE | NACK Detect Interrupt Enable<br>Enables interrupt for NACK detection.<br>0b - Disable<br>1b - Enable  |
| 9<br>SDIE  | Stop Detect Interrupt Enable<br>Enables interrupt for Stop detection.<br>0b - Disable<br>1b - Enable  |
| 8<br>EPIE  | End Packet Interrupt Enable<br>Enables interrupt for end packet.<br>0b - Disable<br>1b - Enable       |
| 7-2<br>—   | Reserved                                                                                              |
| 1<br>RDIE  | Receive Data Interrupt Enable<br>Enables interrupt for receive data.<br>0b - Disable<br>1b - Enable   |
| 0<br>TDIE  | Transmit Data Interrupt Enable<br>Enables interrupt for transmit data.<br>0b - Disable<br>1b - Enable |

### 36.7.1.7 Controller DMA Enable (MDER)

Offset

| Register | Offset |
|----------|--------|
| MDER     | 1Ch    |

**Function**

Contains DMA transmit, request, and receive enables.

**Diagram**

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

**Fields**

| Field     | Function                                                                              |
|-----------|---------------------------------------------------------------------------------------|
| 31-2      | Reserved                                                                              |
| —         |                                                                                       |
| 1<br>RDDE | Receive Data DMA Enable<br>Enables DMA receive data.<br>0b - Disable<br>1b - Enable   |
| 0<br>TDDE | Transmit Data DMA Enable<br>Enables DMA transmit data.<br>0b - Disable<br>1b - Enable |

**36.7.1.8 Controller Configuration 0 (MCFGR0)****Offset**

| Register | Offset |
|----------|--------|
| MCFGR0   | 20h    |

**Function**

Contains host settings and other receive and transfer settings.

**Diagram**

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24      | 23 | 22 | 21 | 20 | 19 | 18 | 17    | 16    |       |      |
|-------|----|----|----|----|----|----|------|---------|----|----|----|----|----|----|-------|-------|-------|------|
| R     |    |    |    |    |    |    |      | 0       |    |    |    |    |    |    | ABORT | RELAX |       |      |
| W     |    |    |    |    |    |    |      |         |    |    |    |    |    |    |       |       |       |      |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0     |       |      |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8       | 7  | 6  | 5  | 4  | 3  | 2  | 1     | 0     |       |      |
| R     |    |    |    |    | 0  |    |      |         |    |    |    |    |    |    | HRDIR | HRSEL | HRPOL | HREN |
| W     |    |    |    |    |    |    | RDMO | CIRFIFO |    |    |    |    |    |    |       |       |       |      |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0     | 0     | 0    |

**Fields**

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-18<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 17<br>ABORT  | Abort Transfer<br>Determines whether the LPI2C controller completes the existing byte and then sends a Stop condition. A new transfer does not start while this field is 1.<br>0b - Normal transfer<br>1b - Abort existing transfer and do not start a new one                                                                                                                                                                                                   |
| 16<br>RELAX  | Relaxed Mode<br>Specifies the type of transfer. If this field is 1, the LPI2C controller relaxes several transfer restrictions. Transfers start when the bus is busy and FIFO commands are not checked for errors. You can use this mode to attempt recovery of a stuck I2C target by toggling the SCL pin.<br>0b - Normal transfer<br>1b - Relaxed transfer                                                                                                     |
| 15-10<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 9<br>RDMO    | Receive Data Match Only<br>Determines whether all received data that does not set <a href="#">MSR[DMF]</a> is discarded. After <a href="#">MSR[DMF]</a> is set, the RDMO configuration is ignored. When disabling RDMO, write 0 to this field before writing 0 to <a href="#">MSR[DMF]</a> to ensure that no receive data is lost.<br>0b - Received data is stored in the receive FIFO<br>1b - Received data is discarded unless <a href="#">MSR[DMF]</a> is set |
| 8<br>CIRFIFO | Circular FIFO Enable<br>Enables the transmit FIFO read pointer to be saved to a temporary register. The transmit FIFO empties as normal. After the LPI2C controller is idle and the transmit FIFO is empty, the read pointer value is                                                                                                                                                                                                                            |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | <p>restored from the temporary register. This setting causes the contents of the transmit FIFO to be cycled through repeatedly. If <a href="#">MCFG1[AUTOSTOP]</a> is 1, then a Stop condition is sent whenever the transmit FIFO is empty and the read pointer is restored.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                                       |
| 7-4<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3<br>HRDIR | <p><b>Host Request Direction</b></p> <p>Configures the direction of the HREQ pin. When this field is 1, the LPI2C target drives the HREQ output pin and the pin becomes 1 when there is data in the target transmit data register. For proper operation when this field is 1, write 1 to <a href="#">SCFGR1[TXCFG]</a>.</p> <p>0b - HREQ pin is input (for LPI2C controller)<br/>1b - HREQ pin is output (for LPI2C target)</p>                                                                                                                                                                            |
| 2<br>HRSEL | <p><b>Host Request Select</b></p> <p>Selects the source of the host request input. When host request is enabled, this field must not change.</p> <p>0b - Host request input is pin HREQ<br/>1b - Host request input is input trigger</p>                                                                                                                                                                                                                                                                                                                                                                   |
| 1<br>HRPOL | <p><b>Host Request Polarity</b></p> <p>Configures the polarity of the host request input. When host request is enabled, this field must not change. HRPOL sets the polarity for both the HREQ pin and the input trigger.</p> <ul style="list-style-type: none"> <li>When HRPOL=0, the polarity is configured for active low, so host request is asserted if the HREQ pin or input trigger are logic 0.</li> <li>When HRPOL=1, the polarity is configured for active high, so host request is asserted if the HREQ pin or input trigger are logic 1.</li> </ul> <p>0b - Active low<br/>1b - Active high</p> |
| 0<br>HREN  | <p><b>Host Request Enable</b></p> <p>Enables host request. When enabled, the LPI2C controller only initiates a Start condition if the host request input is asserted and the bus is idle. A repeated Start condition is not affected by the host request.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                                                          |

### 36.7.1.9 Controller Configuration 1 (MCFGR1)

#### Offset

| Register | Offset |
|----------|--------|
| MCFGR1   | 24h    |

#### Function

Contains controls for pin configuration, clock prescaler, and various other control settings.

Write to this register only when the I2C controller is disabled.

#### Diagram

| Bits  | 31 | 30 | 29 | 28 | 27           | 26   | 25     | 24    | 23   | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|--------------|------|--------|-------|------|----|----|----|----|----|----|----|
| R     | 0  |    |    |    |              |      |        |       | 0    |    |    |    |    |    |    |    |
| W     |    |    |    |    | Reserv<br>ed |      | PINCFG |       |      |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0            | 0    | 0      | 0     | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bits  | 15 | 14 | 13 | 12 | 11           | 10   | 9      | 8     | 7    | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     | 0  |    |    |    | STAR         | STOP | TIMEC  | IGNAC | AUTO | 0  |    |    |    |    |    |    |
| W     |    |    |    |    | TCFG         | CFG  | FG     | K     | STOP |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0            | 0    | 0      | 0     | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

#### Fields

| Field  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-28  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| —      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 27     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| —      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 26-24  | Pin Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| PINCFG | <p>Configures the pin mode for LPI2C.</p> <p>000b - Two-pin open drain mode. SCL/SDA pins: Bidirectional open drain for controller and target. SCLS/SDAS pins: Not used.</p> <p>001b - Two-pin output only mode (Ultra-Fast mode). SCL/SDA pins: Output-only (Ultra-Fast mode) open drain for controller and target. SCLS/SDAS pins: Not used.</p> <p>010b - Two-pin push-pull mode. SCL/SDA pins: Bidirectional push-pull for controller and target. SCLS/SDAS pins: Not used.</p> <p>011b - Four-pin push-pull mode. SCL/SDA pins: Input only for controller and target. SCLS/SDAS pins: Output-only push-pull for controller and target.</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | <p>100b - Two-pin open-drain mode with separate LPI2C target. SCL/SDA pins: Bidirectional open drain for controller. SCLS/SDAS pins: Bidirectional open drain for target.</p> <p>101b - Two-pin output only mode (Ultra-Fast mode) with separate LPI2C target. SCL/SDA pins: Output-only (Ultra-Fast mode) open drain for controller. SCLS/SDAS pins: Output-only open drain for target.</p> <p>110b - Two-pin push-pull mode with separate LPI2C target. SCL/SDA pins: Bidirectional push-pull for controller. SCLS/SDAS pins: Bidirectional push-pull for target.</p> <p>111b - Four-pin push-pull mode (inverted outputs). SCL/SDA pins: Input only for controller and target. SCLS/SDAS pins: Inverted output-only push-pull for controller and target.</p>                                                               |
| 23-19<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 18-16<br>MATCFG | <p>Match Configuration</p> <p>Configures the condition that sets <a href="#">MSR[DMF]</a>. See <a href="#">Controller Data Match (MDMR)</a>.</p> <p>000b - Match is disabled</p> <p>001b - Reserved</p> <p>010b - Match is enabled: first data word equals MDMR[MATCH0] OR MDMR[MATCH1]</p> <p>011b - Match is enabled: any data word equals MDMR[MATCH0] OR MDMR[MATCH1]</p> <p>100b - Match is enabled: (first data word equals MDMR[MATCH0]) AND (second data word equals MDMR[MATCH1])</p> <p>101b - Match is enabled: (any data word equals MDMR[MATCH0]) AND (next data word equals MDMR[MATCH1])</p> <p>110b - Match is enabled: (first data word AND MDMR[MATCH1]) equals (MDMR[MATCH0] AND MDMR[MATCH1])</p> <p>111b - Match is enabled: (any data word AND MDMR[MATCH1]) equals (MDMR[MATCH0] AND MDMR[MATCH1])</p> |
| 15-13<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 12<br>STARTCFG  | <p>Start Configuration</p> <p>Configures the conditions that set <a href="#">MSR[STF]</a> when a Start condition occurs.</p> <p>When this field is 0, MSR[STF] is set on a Start condition when both the I2C bus and LPI2C are idle. In other words, any nonrepeated Start condition is initiated by any controller on the bus except the LPI2C controller.</p> <p>When this field is 1, MSR[STF] is set on a Start condition when the I2C bus is idle. In other words, any nonrepeated Start condition is initiated by any controller on the bus including the LPI2C controller.</p> <p>0b - Sets when both I2C bus and LPI2C controller are idle</p> <p>1b - Sets when I2C bus is idle</p>                                                                                                                                  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11<br>STOPCFG   | <p>Stop Configuration</p> <p>Configures the conditions that set <a href="#">MSR[SDF]</a>.</p> <p>When this field is 0, any Stop condition generated by the LPI2C controller sets SDF.</p> <p>When this field is 1, the last Stop condition before the LPI2C controller is idle sets SDF. In this case, the transmit FIFO is empty at the time of the Stop condition.</p> <ul style="list-style-type: none"> <li>0b - Any Stop condition</li> <li>1b - Last Stop condition</li> </ul>    |
| 10<br>TIMECFG   | <p>Timeout Configuration</p> <p>Configures which signals must be low for longer than the configured timeout to set <a href="#">MSR[PLTF]</a>.</p> <p>When this field is 0, MSR[PLTF] is set when SCL is low for longer than the configured timeout.</p> <ul style="list-style-type: none"> <li>0b - SCL</li> <li>1b - SCL or SDA</li> </ul>                                                                                                                                             |
| 9<br>IGNACK     | <p>Ignore NACK</p> <p>Determines whether the LPI2C controller ignores a received NACK and treats it as an ACK. In this case, <a href="#">MSR[NDF]</a> is never set. This field must be 1 in Ultra-Fast mode.</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Treat a received NACK as an ACK</li> </ul>                                                                                                                                                         |
| 8<br>AUTOSTOP   | <p>Automatic Stop Generation</p> <p>Determines whether a Stop condition is generated when the LPI2C controller is busy and the transmit FIFO is empty. A Stop condition can also be generated using a transmit FIFO command.</p> <p>When this field is 1, a Stop condition is automatically generated when the transmit FIFO is empty and the LPI2C controller is busy.</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Stop automatically generated</li> </ul> |
| 7-3<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2-0<br>PRESCALE | <p>Prescaler</p> <p>Configures the clock prescaler used for all LPI2C controller logic except the digital glitch filters.</p> <ul style="list-style-type: none"> <li>000b - Divide by 1</li> <li>001b - Divide by 2</li> <li>010b - Divide by 4</li> <li>011b - Divide by 8</li> <li>100b - Divide by 16</li> </ul>                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function             |
|-------|----------------------|
|       | 101b - Divide by 32  |
|       | 110b - Divide by 64  |
|       | 111b - Divide by 128 |

### 36.7.1.10 Controller Configuration 2 (MCFGR2)

#### Offset

| Register | Offset |
|----------|--------|
| MCFGR2   | 28h    |

#### Function

Contains the configuration for the bus idle timeout and glitch filters for SDA and SCL.

Write to this register only when the I2C controller is disabled.

#### Diagram

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

#### Fields

| Field            | Function                                                                                                                                                                                                                                                                                   |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-28<br>—       | Reserved                                                                                                                                                                                                                                                                                   |
| 27-24<br>FILTSDA | <p>Glitch Filter SDA</p> <p>Configures the I2C controller digital glitch filters for the SDA input.</p> <p>The latency through the glitch filter is equal to the number of cycles defined by this field. The value of this field must be less than the minimum SCL low or high period.</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <p>Glitches equal to or less than the number of cycles defined by this field are filtered out and ignored. Writing 0 to this field disables the glitch filter.</p> <p><a href="#">MCFGR1[PRESCALE]</a> does not affect the glitch filter cycle count. It is automatically bypassed in HS mode.</p>                                                                                                                                                                                                                                                                                                                                        |
| 23-20<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 19-16<br>FILTSCL | <p>Glitch Filter SCL</p> <p>Configures the I2C controller digital glitch filters for SCL input.</p> <p>The latency through the glitch filter is equal to the number of cycles defined by this field. The value of this field must be less than the minimum SCL low or high period.</p> <p>Glitches equal to or less than the number of cycles defined by this field are filtered out and ignored. These cycles are based on the functional clock. Writing 0 to this field disables the glitch filter.</p> <p><a href="#">MCFGR1[PRESCALE]</a> does not affect the glitch filter cycle count. It is automatically bypassed in HS mode.</p> |
| 15-12<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 11-0<br>BUSIDLE  | <p>Bus Idle Timeout</p> <p>Configures the bus idle timeout period, in clock cycles.</p> <p>If both SCL and SDA are high for longer than the number of cycles defined by this field, the I2C bus is assumed to be idle and the controller can generate a Start condition.</p> <p>Writing 0 to this field disables the bus idle timeout.</p>                                                                                                                                                                                                                                                                                                |

### 36.7.1.11 Controller Configuration 3 (MCFGR3)

#### Offset

| Register | Offset |
|----------|--------|
| MCFGR3   | 2Ch    |

#### Function

Configures the threshold value for the pin low timeout flag.

Write to this register only when the I2C controller is disabled.

**Diagram**

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

**Fields**

| Field          | Function                                                                                                                                                                                                                                                                                                                |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-20<br>—     | Reserved                                                                                                                                                                                                                                                                                                                |
| 19-8<br>PINLOW | Pin Low Timeout<br><br>Configures the threshold value, in clock cycles, that sets <a href="#">MSR[PLTF]</a> .<br><br>If SCL or SDA (selected by <a href="#">MCFGR1[TIMECFG]</a> ) is low for longer than (PINLOW × 256) cycles, MSR[PLTF] is set.<br><br>When this field is 0, the pin low timeout feature is disabled. |
| 7-0<br>—       | Reserved                                                                                                                                                                                                                                                                                                                |

**36.7.1.12 Controller Data Match (MDMR)****Offset**

| Register | Offset |
|----------|--------|
| MDMR     | 40h    |

**Function**

Contains data match values.

Write to this register only when the I2C controller is disabled or idle.

**Diagram**

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

**Fields**

| Field  | Function                                                                                          |
|--------|---------------------------------------------------------------------------------------------------|
| 31-24  | Reserved                                                                                          |
| —      |                                                                                                   |
| 23-16  | Match 1 Value                                                                                     |
| MATCH1 | Specifies match 1 value that is compared to the received data when receive data match is enabled. |
| 15-8   | Reserved                                                                                          |
| —      |                                                                                                   |
| 7-0    | Match 0 Value                                                                                     |
| MATCH0 | Specifies match 0 value that is compared to the received data when receive data match is enabled. |

**36.7.1.13 Controller Clock Configuration 0 (MCCR0)****Offset**

| Register | Offset |
|----------|--------|
| MCCR0    | 48h    |

**Function**

Configures various clock controls.

You cannot make changes to this register when the I2C controller is enabled and is used for standard, fast, fast-mode plus, and ultra-fast transfers.

**Diagram**

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

**Fields**

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 29-24<br>DATAVD  | Data Valid Delay<br>Specifies the minimum number of cycles (minus one) used as the data hold time for SDA. This value must be less than the minimum SCL low period.                                                                                                                                                                                                                                                                                                                                                        |
| 23-22<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 21-16<br>SETHOLD | Setup Hold Delay<br>Specifies the minimum number of cycles (minus one) used by the controller for these conditions: <ul style="list-style-type: none"><li>• Hold time for a Start</li><li>• Setup and hold time for a repeated Start</li><li>• Setup time for a Stop</li></ul> The setup time is extended by the time it takes to detect a rising edge on the external SCL pin. Ignoring any additional board delay due to external loading, this time is equal to $(2 + \text{FILTSCL}) \div 2^{\text{PRESCALE}}$ cycles. |
| 15-14<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 13-8<br>CLKHI    | Clock High Period<br>Specifies the minimum number of cycles (minus one) that the controller drives the SCL clock high. The SCL high time is extended by the time needed to detect a rising edge on the external SCL pin. Ignoring any additional board delay due to external loading, this time is equal to $(2 + \text{FILTSCL}) \div 2^{\text{PRESCALE}}$ cycles.                                                                                                                                                        |
| 7-6<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5-0<br>CLKLO | Clock Low Period<br><br>Specifies the minimum number of cycles (minus one) that the controller drives the SCL clock low. This value is also used for the minimum bus free time between a Stop and a Start condition. This period is extended by the time needed to detect a rising edge on the external SCL pin. Ignoring any additional board delay due to external loading, this time is equal to $(2 + \text{FILTSCL}) \div 2^{\text{PRESCALE}}$ cycles. |

### 36.7.1.14 Controller Clock Configuration 1 (MCCR1)

#### Offset

| Register | Offset |
|----------|--------|
| MCCR1    | 50h    |

#### Function

Configures various clock controls.

You cannot make changes to this register when the I2C controller is enabled and is used for HS mode transfers. The separate clock configuration for HS mode allows arbitration to take place in Fast mode (with timing configured by [Controller Clock Configuration 0 \(MCCR0\)](#)), before switching to HS mode (with timing configured by MCCR1).

#### Diagram



#### Fields

| Field           | Function         |
|-----------------|------------------|
| 31-30<br>—      | Reserved         |
| 29-24<br>DATAVD | Data Valid Delay |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | Specifies the minimum number of cycles (minus one) used as the data hold time for SDA. This value must be less than the minimum SCL low period.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 23-22<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 21-16<br>SETHOLD | <p>Setup Hold Delay</p> <p>Specifies the minimum number of cycles (minus one) used by the controller for these conditions:</p> <ul style="list-style-type: none"> <li>• Hold time for a Start condition</li> <li>• Setup and hold time for a repeated Start condition</li> <li>• Setup time for a Stop condition</li> </ul> <p>The setup time is extended by the time needed to detect a rising edge on the external SCL pin. Ignoring any additional board delay due to external loading, this time is equal to <math>(2 + \text{FILTSCL}) \div 2^{\text{PRESCALE}}</math> cycles.</p> |
| 15-14<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 13-8<br>CLKHI    | <p>Clock High Period</p> <p>Specifies the minimum number of cycles (minus one) that the controller drives the SCL clock high. The SCL high time is extended by the time needed to detect a rising edge on the external SCL pin. Ignoring any additional board delay due to external loading, this time is equal to <math>(2 + \text{FILTSCL}) \div 2^{\text{PRESCALE}}</math> cycles.</p>                                                                                                                                                                                               |
| 7-6<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 5-0<br>CLKLO     | <p>Clock Low Period</p> <p>Specifies the minimum number of cycles (minus one) that the controller drives the SCL clock low. This value is also used for the minimum bus free time between a Stop and a Start condition. This period is extended by the time needed to detect a rising edge on the external SCL pin. Ignoring any additional board delay due to external loading, this time is equal to <math>(2 + \text{FILTSCL}) \div 2^{\text{PRESCALE}}</math> cycles.</p>                                                                                                           |

### 36.7.1.15 Controller FIFO Control (MFCR)

#### Offset

| Register | Offset |
|----------|--------|
| MFCR     | 58h    |

#### Function

Controls the receive and transmit FIFO watermark values.

This register is used only in Stop mode, when this register is static (not changing).

**Diagram**

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

**Fields**

| Field            | Function                                                                                                                                                                                                                                                                             |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-18<br>—       | Reserved                                                                                                                                                                                                                                                                             |
| 17-16<br>RXWATER | Receive FIFO Watermark<br>Determines the watermark for setting <a href="#">SSR[RDF]</a> . That flag is set when the number of words in the receive FIFO is greater than the value of this field. Writing a value equal to or greater than the FIFO size truncates the value.         |
| 15-2<br>—        | Reserved                                                                                                                                                                                                                                                                             |
| 1-0<br>TXWATER   | Transmit FIFO Watermark<br>Determines the watermark for setting <a href="#">SSR[TDF]</a> . That flag is set when the number of words in the transmit FIFO is equal or less than the value of this field. Writing a value equal to or greater than the FIFO size truncates the value. |

**36.7.1.16 Controller FIFO Status (MFSR)****Offset**

| Register | Offset |
|----------|--------|
| MFSR     | 5Ch    |

**Function**

Specifies the number of words in the transmit and receive FIFOs.

**Diagram**

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

**Fields**

| Field   | Function                                            |
|---------|-----------------------------------------------------|
| 31-19   | Reserved                                            |
| —       |                                                     |
| 18-16   | Receive FIFO Count                                  |
| RXCOUNT | Specifies the number of words in the receive FIFO.  |
| 15-3    | Reserved                                            |
| —       |                                                     |
| 2-0     | Transmit FIFO Count                                 |
| TXCOUNT | Specifies the number of words in the transmit FIFO. |

**36.7.1.17 Controller Transmit Data (MTDR)****Offset**

| Register | Offset |
|----------|--------|
| MTDR     | 60h    |

**Function**

Configures transmit data:

- An 8-bit write to [MTDR\[CMD\]](#) is ignored and does not increment the FIFO write pointer.
- An 8-bit write to [MTDR\[DATA\]](#) zero-extends the value of MTDR[CMD] and increments the FIFO write pointer.
- A 16-bit or 32-bit write operation writes to both MTDR[CMD] and MTDR[DATA] and increments the FIFO write pointer.

**Diagram**

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

**Fields**

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-11<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 10-8<br>CMD | <p>Command Data</p> <p>Selects command transmitted by controller.</p> <ul style="list-style-type: none"> <li>000b - Transmit the value in DATA[7:0]</li> <li>001b - Receive (DATA[7:0] + 1) bytes. DATA[7:0] is used as a byte counter. Receive that many bytes and check each for a data match (if configured) before storing the received data in the receive FIFO.</li> <li>010b - Generate Stop condition on I2C bus</li> <li>011b - Receive and discard (DATA[7:0] + 1) bytes. DATA[7:0] is used as a byte counter. Receive that many bytes but do not check for a data match or store those bytes in the receive FIFO.</li> <li>100b - Generate (repeated) Start on the I2C bus and transmit the address in DATA[7:0]</li> <li>101b - Generate (repeated) Start on the I2C bus and transmit the address in DATA[7:0] (this transfer expects a NACK to be returned)</li> <li>110b - Generate (repeated) Start on the I2C bus and transmit the address in DATA[7:0] using HS mode</li> <li>111b - Generate (repeated) Start on the I2C bus and transmit the address in DATA[7:0] using HS mode (this transfer expects a NACK to be returned)</li> </ul> |
| 7-0<br>DATA | <p>Transmit Data</p> <p>Contains data used by the commands listed in MTDR[CMD]. Performing an 8-bit write to this field zero-extends the value of <a href="#">MTDR[CMD]</a>.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

### 36.7.1.18 Controller Receive Data (MRDR)

#### Offset

| Register | Offset |
|----------|--------|
| MRDR     | 70h    |

#### Function

Contains the status of the receive FIFO and the data received by the I2C controller that has not been discarded.

#### Diagram



#### Fields

| Field         | Function                                                                                                                                                                                                                                    |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-15<br>—    | Reserved                                                                                                                                                                                                                                    |
| 14<br>RXEMPTY | Receive Empty<br>Indicates whether the controller receive data FIFO is empty.<br>0b - Not empty<br>1b - Empty                                                                                                                               |
| 13-8<br>—     | Reserved                                                                                                                                                                                                                                    |
| 7-0<br>DATA   | Receive Data<br>Contains data received by the I2C controller that has not been discarded. Received data can be discarded due to the command in <a href="#">MTDR[CMD]</a> , or the controller can be configured to discard nonmatching data. |

### 36.7.1.19 Controller Receive Data Read Only (MRDROR)

#### Offset

| Register | Offset |
|----------|--------|
| MRDROR   | 78h    |

#### Function

Contains the status of the receive FIFO and returns the data received by the I2C controller, but does not pull the data from the FIFO.

#### Diagram

| Bits  | 31 | 30          | 29 | 28 | 27 | 26 | 25 | 24   | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|-------------|----|----|----|----|----|------|----|----|----|----|----|----|----|----|
| R     | 0  |             |    |    |    |    |    |      |    |    |    |    |    |    |    |    |
| W     |    |             |    |    |    |    |    |      |    |    |    |    |    |    |    |    |
| Reset | 0  | 0           | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bits  | 15 | 14          | 13 | 12 | 11 | 10 | 9  | 8    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     | 0  | RXEM<br>PTY |    | 0  |    |    |    | DATA |    |    |    |    |    |    |    |    |
| W     |    |             |    |    |    |    |    |      |    |    |    |    |    |    |    |    |
| Reset | 0  | 1           | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

#### Fields

| Field         | Function                                                                                      |
|---------------|-----------------------------------------------------------------------------------------------|
| 31-15<br>—    | Reserved                                                                                      |
| 14<br>RXEMPTY | RX Empty<br>Indicates whether the receive data FIFO is empty.<br>0b - Not empty<br>1b - Empty |
| 13-8<br>—     | Reserved                                                                                      |
| 7-0<br>DATA   | Receive Data                                                                                  |

### 36.7.1.20 Target Control (SCR)

#### Offset

| Register | Offset |
|----------|--------|
| SCR      | 110h   |

#### Function

Contains resets and other target control settings.

#### Diagram



#### Fields

| Field      | Function                                                                                                                                      |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 31-10<br>— | Reserved                                                                                                                                      |
| 9<br>RRF   | Reset Receive FIFO<br>Empties the receive FIFO in <a href="#">Target Receive Data (SRDR)</a> .<br>0b - No effect<br>1b - SRDR is now empty    |
| 8<br>RTF   | Reset Transmit FIFO<br>Empties the transmit FIFO in <a href="#">Target Transmit Data (STDR)</a> .<br>0b - No effect<br>1b - STDR is now empty |
| 7-6<br>—   | Reserved                                                                                                                                      |
| 5          | Filter Doze Enable                                                                                                                            |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                          |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FILTDZ      | Enables filter in Doze mode. Update this field only when the I2C target is disabled.<br>0b - Enable<br>1b - Disable                                                                                                                               |
| 4<br>FILTEN | Filter Enable<br>Enables digital filter and output delay counter for target mode. Update this field only when the I2C target is disabled.<br>0b - Disable<br>1b - Enable                                                                          |
| 3-2<br>—    | Reserved                                                                                                                                                                                                                                          |
| 1<br>RST    | Software Reset<br>Resets target mode logic. The reset takes effect immediately. The value of this field remains 1 until you write 0 to it. There is no minimum delay required before clearing the software reset.<br>0b - Not reset<br>1b - Reset |
| 0<br>SEN    | Target Enable<br>Enables I2C Target mode.<br>0b - Disable<br>1b - Enable                                                                                                                                                                          |

### 36.7.1.21 Target Status (SSR)

#### Offset

| Register | Offset |
|----------|--------|
| SSR      | 114h   |

#### Function

Contains status flags for transmit and receive data, for error conditions, and for bus and target busy or idle status.

**Diagram**

| Bits  | 31   | 30  | 29   | 28   | 27  | 26  | 25  | 24  | 23 | 22 | 21 | 20 | 19  | 18  | 17  | 16  |
|-------|------|-----|------|------|-----|-----|-----|-----|----|----|----|----|-----|-----|-----|-----|
| R     |      |     |      | 0    |     |     | BBF | SBF |    |    |    |    | 0   |     |     |     |
| W     |      |     |      |      |     |     |     |     |    |    |    |    |     |     |     |     |
| Reset | 0    | 0   | 0    | 0    | 0   | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0   | 0   | 0   | 0   |
| Bits  | 15   | 14  | 13   | 12   | 11  | 10  | 9   | 8   | 7  | 6  | 5  | 4  | 3   | 2   | 1   | 0   |
| R     | SARF | GCF | AM1F | AM0F | FEF | BEF | SDF | RSF |    |    |    |    | TAF | AVF | RDF | TDF |
| W     |      |     |      |      | W1C | W1C | W1C | W1C |    |    |    |    |     |     |     |     |
| Reset | 0    | 0   | 0    | 0    | 0   | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0   | 0   | 0   | 0   |

**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                       |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-26<br>— | Reserved                                                                                                                                                                                                                                                                                       |
| 25<br>BBF  | Bus Busy Flag<br>Indicates whether an I2C bus is idle or busy.<br>0b - Idle<br>1b - Busy                                                                                                                                                                                                       |
| 24<br>SBF  | Target Busy Flag<br>Indicates whether an I2C target is idle or busy.<br>0b - Idle<br>1b - Busy                                                                                                                                                                                                 |
| 23-16<br>— | Reserved                                                                                                                                                                                                                                                                                       |
| 15<br>SARF | SMBus Alert Response Flag<br>Indicates whether an SMBus alert response has been detected.<br>You can clear this flag by reading <a href="#">Target Address Status (SASR)</a> . This flag cannot generate an asynchronous wakeup.<br>0b - Disabled or not detected<br>1b - Enabled and detected |
| 14<br>GCF  | General Call Flag<br>Indicates whether a target has detected the general call address.<br>You can clear this flag by reading <a href="#">Target Address Status (SASR)</a> . This flag cannot generate an asynchronous wakeup.                                                                  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | <p>0b - General call address disabled or not detected<br/>1b - General call address detected</p>                                                                                                                                                                                                                                                                                                                  |
| 13<br>AM1F | <p>Address Match 1 Flag<br/>Indicates whether the received address matches the value in ADDR1, or it falls within the ADDR0 to ADDR1 range as configured by <a href="#">SCFGR1[ADDRCFG]</a>.<br/>This flag is cleared by reading <a href="#">Target Address Status (SASR)</a>. This flag cannot generate an asynchronous wakeup.</p> <p>0b - Matching address not received<br/>1b - Matching address received</p> |
| 12<br>AM0F | <p>Address Match 0 Flag<br/>Indicates whether the received address matches the ADDR0 field, as configured by <a href="#">SCFGR1[ADDRCFG]</a>.<br/>This flag is cleared by reading <a href="#">Target Address Status (SASR)</a>. This flag cannot generate an asynchronous wakeup.</p> <p>0b - ADDR0 matching address not received<br/>1b - ADDR0 matching address received</p>                                    |
| 11<br>FEF  | <p>FIFO Error Flag<br/>Indicates whether there is a FIFO error. This flag can only be set when clock stretching is disabled.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p> <p>0b - No FIFO error<br/>1b - FIFO error</p> <p>When writing</p> <p>0b - No effect<br/>1b - Clear the flag</p>                                                         |
| 10<br>BEF  | <p>Bit Error Flag<br/>Indicates whether the LPI2C target has transmitted a logic 1 and detects a logic 0 on the I2C bus. The target ignores the rest of the transfer until the next (repeated) Start condition.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p> <p>0b - No bit error occurred</p>                                                    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | <p>1b - Bit error occurred<br/>When writing<br/>0b - No effect<br/>1b - Clear the flag</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 9<br>SDF | <p>Stop Detect Flag<br/>Indicates whether the LPI2C target detects a Stop condition, and if the LPI2C target matched the last address byte. When <a href="#">SCFGR1[SDCFG]</a> = 1, this flag is set on any Stop condition.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading<br/>0b - No Stop detected<br/>1b - Stop detected<br/>When writing<br/>0b - No effect<br/>1b - Clear the flag</p>                                                                                                                 |
| 8<br>RSF | <p>Repeated Start Flag<br/>Indicates whether the LPI2C target detects a repeated Start condition and if the LPI2C target matched the last address byte. When <a href="#">SCFGR1[RSCFG]</a> = 1, this flag is set on any repeated Start condition. This flag is not set when the target first detects a Start condition.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading<br/>0b - No repeated Start detected<br/>1b - Repeated Start detected<br/>When writing<br/>0b - No effect<br/>1b - Clear the flag</p> |
| 7-4<br>— | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3<br>TAF | <p>Transmit ACK Flag<br/>Indicates whether a transmit ACK or NACK is required. You can clear this flag by writing to <a href="#">Target Transmit ACK (STAR)</a>.<br/>0b - Not required</p>                                                                                                                                                                                                                                                                                                                                                                            |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                      |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 1b - Required                                                                                                                                                                                                                                                                                                                                                                 |
| 2<br>AVF | <p>Address Valid Flag</p> <p>Indicates whether the contents of <a href="#">Target Address Status (SASR)</a> are valid. You can clear this flag by reading SASR. When <a href="#">SCFGR1[RXCFG]</a> = 1, this flag is also cleared by reading <a href="#">Target Receive Data (SRDR)</a>.</p> <p>0b - Not valid<br/>1b - Valid</p>                                             |
| 1<br>RDF | <p>Receive Data Flag</p> <p>Indicates whether receive data is ready. You can clear this flag by reading <a href="#">Target Receive Data (SRDR)</a>. When <a href="#">SCFGR1[RXCFG]</a> = 1, this flag is not cleared when reading <a href="#">Target Receive Data (SRDR)</a> if <a href="#">SSR[AVF]</a> = 1.</p> <p>0b - Not ready<br/>1b - Ready</p>                        |
| 0<br>TDF | <p>Transmit Data Flag</p> <p>Indicates whether transmit data has been requested. This flag is cleared by writing to <a href="#">Target Transmit Data (STDR)</a>. When <a href="#">SCFGR1[TXCFG]</a> = 0, if a NACK, repeated Start, or Stop condition is detected, this flag is also cleared.</p> <p>0b - Transmit data not requested<br/>1b - Transmit data is requested</p> |

### 36.7.1.22 Target Interrupt Enable (SIER)

#### Offset

| Register | Offset |
|----------|--------|
| SIER     | 118h   |

#### Function

Contains transmit and receive data interrupt enables, start and stop detect interrupt enables, and other target interrupt enables.

**Diagram**

| Bits  | 31    | 30   | 29    | 28    | 27   | 26   | 25   | 24   | 23 | 22 | 21 | 20 | 19   | 18   | 17   | 16   |
|-------|-------|------|-------|-------|------|------|------|------|----|----|----|----|------|------|------|------|
| R     | 0     |      |       |       |      |      |      |      |    |    |    |    |      |      |      |      |
| W     |       |      |       |       |      |      |      |      |    |    |    |    |      |      |      |      |
| Reset | 0     | 0    | 0     | 0     | 0    | 0    | 0    | 0    | 0  | 0  | 0  | 0  | 0    | 0    | 0    | 0    |
| Bits  | 15    | 14   | 13    | 12    | 11   | 10   | 9    | 8    | 7  | 6  | 5  | 4  | 3    | 2    | 1    | 0    |
| R     | SARIE | GCIE | AM1IE | AM0IE | FEIE | BEIE | SDIE | RSIE | 0  |    |    |    | TAIE | AVIE | RDIE | TDIE |
| W     | 0     | 0    | 0     | 0     | 0    | 0    | 0    | 0    | 0  | 0  | 0  | 0  | 0    | 0    | 0    | 0    |
| Reset | 0     | 0    | 0     | 0     | 0    | 0    | 0    | 0    | 0  | 0  | 0  | 0  | 0    | 0    | 0    | 0    |

**Fields**

| Field       | Function                                                                                                            |
|-------------|---------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—  | Reserved                                                                                                            |
| 15<br>SARIE | SMBus Alert Response Interrupt Enable<br>Enables interrupt for SMBus alert response.<br>0b - Disable<br>1b - Enable |
| 14<br>GCIE  | General Call Interrupt Enable<br>Enables interrupt for general call.<br>0b - Disabled<br>1b - Enabled               |
| 13<br>AM1IE | Address Match 1 Interrupt Enable<br>Enables interrupt for address match 1.<br>0b - Disable<br>1b - Enable           |
| 12<br>AM0IE | Address Match 0 Interrupt Enable<br>Enables interrupt for address match 0.<br>0b - Disable<br>1b - Enable           |
| 11<br>FEIE  | FIFO Error Interrupt Enable<br>Enables interrupt for FIFO error.<br>0b - Disable<br>1b - Enable                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                |
|------------|---------------------------------------------------------------------------------------------------------|
| 10<br>BEIE | Bit Error Interrupt Enable<br>Enables interrupt for bit error.<br>0b - Disable<br>1b - Enable           |
| 9<br>SDIE  | Stop Detect Interrupt Enable<br>Enables interrupt for Stop detection.<br>0b - Disable<br>1b - Enable    |
| 8<br>RSIE  | Repeated Start Interrupt Enable<br>Enables interrupt for repeated start.<br>0b - Disable<br>1b - Enable |
| 7-4<br>—   | Reserved                                                                                                |
| 3<br>TAIE  | Transmit ACK Interrupt Enable<br>Enables interrupt for transmit ACK.<br>0b - Disable<br>1b - Enable     |
| 2<br>AVIE  | Address Valid Interrupt Enable<br>Enables interrupt for valid address.<br>0b - Disable<br>1b - Enable   |
| 1<br>RDIE  | Receive Data Interrupt Enable<br>Enables interrupt for receive data.<br>0b - Disable<br>1b - Enable     |
| 0<br>TDIE  | Transmit Data Interrupt Enable<br>Enables interrupt for transmit data.<br>0b - Disable<br>1b - Enable   |

### 36.7.1.23 Target DMA Enable (SDER)

#### Offset

| Register | Offset |
|----------|--------|
| SDER     | 11Ch   |

#### Function

Contains the transmit, request, and receive enables for DMA.

#### Diagram



#### Fields

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                    |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-10<br>— | Reserved                                                                                                                                                                                                                                                                                                                                                                    |
| 9<br>SDDE  | <p>Stop Detect DMA Enable</p> <p>Enables DMA end-of-packet processing on stop detection. Reading <a href="#">Target Receive Data (SRDR)</a> when it is empty:</p> <ul style="list-style-type: none"> <li>Generates a DMA end-of-packet response.</li> <li>Returns 0000_40FFh.</li> <li>Writes 0 to <a href="#">MSR[SDF]</a>.</li> </ul> <p>0b - Disable<br/>1b - Enable</p> |
| 8<br>RSDE  | <p>Repeated Start DMA Enable</p> <p>Enables DMA end-of-packet processing on repeated start. Reading <a href="#">Target Receive Data (SRDR)</a> when it is empty:</p> <ul style="list-style-type: none"> <li>Generates a DMA end-of-packet response.</li> </ul>                                                                                                              |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                                                                                                                                                      |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | <ul style="list-style-type: none"> <li>Returns 0000_40FFh.</li> <li>Writes 0 to <a href="#">MSR[RDF]</a>.</li> </ul> 0b - Disable<br>1b - Enable                                                                                                                                                                              |
| 7-3<br>—  | Reserved                                                                                                                                                                                                                                                                                                                      |
| 2<br>AVDE | Address Valid DMA Enable<br>Enables address valid DMA request. The address valid DMA request is shared with the receive data DMA request. If both are enabled, write 1 to <a href="#">SCFGR1[RXCFG]</a> to allow the DMA to read the address from <a href="#">Target Receive Data (SRDR)</a> .<br>0b - Disable<br>1b - Enable |
| 1<br>RDDE | Receive Data DMA Enable<br>Enables receive data for DMA.<br>0b - Disable DMA request<br>1b - Enable DMA request                                                                                                                                                                                                               |
| 0<br>TDDE | Transmit Data DMA Enable<br>Enables transmit data for DMA.<br>0b - Disable<br>1b - Enable                                                                                                                                                                                                                                     |

### 36.7.1.24 Target Configuration 0 (SCFGR0)

#### Offset

| Register | Offset |
|----------|--------|
| SCFGR0   | 120h   |

#### Function

Configures the read request feature.

**Diagram**

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

**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1<br>RDACK | <p>Read Acknowledge Flag</p> <p>Indicates whether a Start then Stop sequence with one SCL pulse between them acknowledged the read request while <a href="#">SCFGR0[RDREQ]</a> = 1. You can clear this flag by writing 0 to SCFGR0[RDREQ].</p> <p>0b - Read Request not acknowledged<br/>1b - Read Request acknowledged</p>                                                                                                                                                                                                                                     |
| 0<br>RDREQ | <p>Read Request</p> <p>Enables read request. When the I2C bus is idle, writing 1 to this field causes the LPI2C target to drive SDA low, triggering a Start condition. The LPI2C target releases SDA on the next falling edge of SCL or when you write 0 to this field.</p> <p>To initiate a second read request (for example, following I2C bus activity that did not acknowledge the request), write 0 then 1 to this field.</p> <p>When the I2C bus is busy, writing to this register always writes 0 to this field.</p> <p>0b - Disable<br/>1b - Enable</p> |

**36.7.1.25 Target Configuration 1 (SCFGR1)****Offset**

| Register | Offset |
|----------|--------|
| SCFGR1   | 124h   |

**Function**

Configures various aspects of the target.

Write to this register only when the I2C target is disabled.

**Diagram**

| Bits  | 31 | 30 | 29        | 28         | 27        | 26        | 25    | 24   | 23 | 22 | 21         | 20           | 19           | 18          | 17           | 16 |  |
|-------|----|----|-----------|------------|-----------|-----------|-------|------|----|----|------------|--------------|--------------|-------------|--------------|----|--|
| R     | 0  |    |           |            | SDCF<br>G | RSCF<br>G | RXALL | 0    |    |    |            | ADDRCFG      |              |             |              |    |  |
|       |    |    |           |            |           |           |       |      |    |    |            |              |              |             |              |    |  |
| Reset | 0  | 0  | 0         | 0          | 0         | 0         | 0     | 0    | 0  | 0  | 0          | 0            | 0            | 0           | 0            | 0  |  |
| Bits  | 15 | 14 | 13        | 12         | 11        | 10        | 9     | 8    | 7  | 6  | 5          | 4            | 3            | 2           | 1            | 0  |  |
| R     | 0  |    | HSME<br>N | IGNAC<br>K | RXC<br>G  | TXC<br>G  | SAEN  | GCEN | 0  |    | RXNA<br>CK | ACKS<br>TALL | TXDS<br>TALL | RXST<br>ALL | ADRS<br>TALL |    |  |
|       |    |    |           |            |           |           |       |      |    |    |            |              |              |             |              |    |  |
| Reset | 0  | 0  | 0         | 0          | 0         | 0         | 0     | 0    | 0  | 0  | 0          | 0            | 0            | 0           | 0            | 0  |  |

**Fields**

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-27<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 26<br>SDCFG | <p>Stop Detect Configuration</p> <p>Configures the conditions that set <a href="#">MSR[SDF]</a>.</p> <p>0b - Any Stop condition following an address match</p> <p>1b - Any Stop condition</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 25<br>RSCFG | <p>Repeated Start Configuration</p> <p>Configures the conditions that set <a href="#">MSR[STF]</a>.</p> <p>0b - Any repeated Start condition following an address match</p> <p>1b - Any repeated Start condition</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 24<br>RXALL | <p>Receive All</p> <p>Enables receive-all functionality.</p> <p>When enabled, the LPI2C target stores all addresses on the I2C bus in <a href="#">Target Address Status (SASR)</a> and all data on the I2C bus in <a href="#">Target Receive Data (SRDR)</a>. However, the LPI2C target does not drive SDA (for ACK or target-transmit transfer) unless there is an address match. The LPI2C target can drive SCL if clock stretching is enabled.</p> <p>When this field is 1, the LPI2C target only supports 7-bit addressing modes (you must configure <a href="#">SCFGR1[ADDRCFG]</a> for 7-bit address match). Software can support 10-bit addresses, however. The first byte of a 10-bit address is saved to <a href="#">Target Address Match (SAMR)</a>. The second byte is saved as the first data byte in <a href="#">Target Receive Data (SRDR)</a>.</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | <p>Use this field to aid debugging of the I2C bus by saving all data on the bus without altering the state of the bus. When this field is 1, it is recommended to also write 1 to <a href="#">SCFGR1[RSCFG]</a> and <a href="#">SCFGR1[SDCFG]</a> so you can track the full state of the I2C bus.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                   |
| 23-19<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 18-16<br>ADDRCFG | <p>Address Configuration</p> <p>Configures the condition that causes an address to match.</p> <p>000b - Address match 0 (7-bit)<br/>001b - Address match 0 (10-bit)<br/>010b - Address match 0 (7-bit) or address match 1 (7-bit)<br/>011b - Address match 0 (10-bit) or address match 1 (10-bit)<br/>100b - Address match 0 (7-bit) or address match 1 (10-bit)<br/>101b - Address match 0 (10-bit) or address match 1 (7-bit)<br/>110b - From address match 0 (7-bit) to address match 1 (7-bit)<br/>111b - From address match 0 (10-bit) to address match 1 (10-bit)</p> |
| 15-14<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 13<br>HSMEN      | <p>HS Mode Enable</p> <p>Enables detection of the HS mode controller code of target address 0000_1XX, but does not cause an address match on this code. When this field is 1 and any HS mode controller code is detected, <a href="#">SCR[FILTEN]</a> and <a href="#">SCFGR1[ACKSTALL]</a> are ignored until the next Stop condition is detected.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                   |
| 12<br>IGNACK     | <p>Ignore NACK</p> <p>Determines whether the target ends transfer when a NACK condition is detected. When this field is 1, the LPI2C target continues transfers after a NACK is detected. This field is required to be 1 in Ultra-Fast mode.</p> <p>0b - End transfer on NACK<br/>1b - Do not end transfer on NACK</p>                                                                                                                                                                                                                                                      |
| 11<br>RXCFG      | <p>Receive Data Configuration</p> <p>Configures which data is returned and which flags are cleared when reading <a href="#">Target Receive Data (SRDR)</a>.</p>                                                                                                                                                                                                                                                                                                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | <p>When this field is 0, reading SRDR returns received data and clears <a href="#">MSR[RDF]</a>.</p> <p>When this field is 1, reading SRDR:</p> <ul style="list-style-type: none"> <li>• Returns the value of <a href="#">Target Address Status (SASR)</a> and clears SSR[AVF] when SSR[AVF] is set.</li> <li>• Returns received data and clears <a href="#">MSR[RDF]</a> when SSR[AVF] is not set.</li> </ul> <p>    0b - Return received data, clear MSR[RDF]</p> <p>    1b - Return SASR and clear SSR[AVF] when SSR[AVF] is set, return received data and clear MSR[RDF] when SSR[AVF] is not set</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 10<br>TXCFG | <p>Transmit Flag Configuration</p> <p>Determines which conditions set <a href="#">MSR[TDF]</a>.</p> <p>This field always becomes 1 before a NACK is detected at the end of a target-transmit transfer. This change can cause an extra word to be written to the transmit data FIFO.</p> <p>When this field is 0, <a href="#">Target Transmit Data (STDR)</a> is automatically emptied when a target-transmit transfer is detected. <a href="#">MSR[TDF]</a> is set when a target-transmit transfer is detected, and <a href="#">MSR[TDF]</a> is cleared at the end of the target-transmit transfer.</p> <p>When this field is 1, <a href="#">MSR[TDF]</a> is set when STDR is empty, and <a href="#">MSR[TDF]</a> is cleared when STDR is full. This setting allows STDR to be filled before a target-transmit transfer is detected. However, it can cause STDR to be written before a NACK is detected on the last byte of a target-transmit transfer.</p> <p>    0b - <a href="#">MSR[TDF]</a> is set only during a target-transmit transfer when STDR is empty</p> <p>    1b - <a href="#">MSR[TDF]</a> is set whenever STDR is empty</p> |
| 9<br>SAEN   | <p>SMBus Alert Enable</p> <p>Enables a match on an SMBus alert.</p> <p>    0b - Disable</p> <p>    1b - Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 8<br>GCEN   | <p>General Call Enable</p> <p>Enables a general call address.</p> <p>    0b - Disable</p> <p>    1b - Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7-5<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4<br>RXNACK | <p>Receive NACK</p> <p>Determines whether to override the setting of <a href="#">STAR[TXNACK]</a> when the LPI2C receives a matching address during an overrun.</p> <p>When this field is 1, the LPI2C target responds with a NACK under the following conditions:</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | <ul style="list-style-type: none"> <li>• <a href="#">SSR[AVF]</a> would be set due to matching an address, but that flag is already 1 (address overrun).</li> <li>• <a href="#">SSR[RDF]</a> would be set due to receiving data, but that flag is already 1 (receive data overrun).</li> </ul> <p>0b - ACK or NACK always determined by <a href="#">STAR[TXNACK]</a><br/>1b - NACK always generated on address overrun or receive data overrun, otherwise ACK or NACK is determined by <a href="#">STAR[TXNACK]</a></p>                                                                                                                                                                                                                                                                                |
| 3<br>ACKSTALL | <p>ACK SCL Stall</p> <p>Enables SCL clock stretching during target-transmit address bytes and target-receiver address and data bytes, so you can write to <a href="#">Target Transmit ACK (STAR)</a> before the ACK or NACK is transmitted. Clock stretching occurs when transmitting the ninth bit, and is therefore not compatible with HS mode.</p> <p>If this field is 1:</p> <ul style="list-style-type: none"> <li>• You do not need to write 1 to <a href="#">SCFGR1[RXSTALL]</a> or <a href="#">SCFGR1[ADRSTALL]</a>.</li> <li>• When there is an address match on the first byte of a 10-bit address, <a href="#">SSR[AVF]</a> is set, allowing you to read the received address before writing to <a href="#">Target Transmit ACK (STAR)</a>.</li> </ul> <p>0b - Disable<br/>1b - Enable</p> |
| 2<br>TXDSTALL | <p>Transmit Data SCL Stall</p> <p>Enables SCL clock stretching when <a href="#">SSR[TDF]</a> = 1 during a target-transmit transfer. Clock stretching occurs following the ninth bit, and is therefore compatible with HS mode.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1<br>RXSTALL  | <p>RX SCL Stall</p> <p>Enables SCL clock stretching when <a href="#">SSR[RDF]</a> = 1 during a target-receive transfer. Clock stretching occurs following the ninth bit, and is therefore compatible with HS mode.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0<br>ADRSTALL | <p>Address SCL Stall</p> <p>Enables SCL clock stretching when <a href="#">SSR[AVF]</a> = 1. Clock stretching only occurs following the ninth bit, and is therefore compatible with HS mode.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

### 36.7.1.26 Target Configuration 2 (SCFGR2)

#### Offset

| Register | Offset |
|----------|--------|
| SCFGR2   | 128h   |

#### Function

Configures data valid delay, clock hold time, and glitch filters for SDA and SCL.

Write to this register only when the I2C target is disabled.

#### Diagram

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

#### Fields

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-28<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 27-24<br>FILTSDA | <p>Glitch Filter SDA</p> <p>Configures the I2C target digital glitch filters for SDA input.</p> <p>Writing 0 to this field disables the glitch filter.</p> <p>Glitches equal to or less than the number of cycles defined by this field are filtered out and ignored.</p> <p>The latency through the glitch filter is equal to the number of cycles defined by this field + 3. The latency must be configured to be less than the minimum SCL low or high period.</p> <p><a href="#">MCFGR1[PRESCALE]</a> does not affect the glitch filter cycle count, and the glitch filter cycle count is disabled in HS mode.</p> |
| 23-20<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 19-16            | Glitch Filter SCL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FILTSCL        | <p>Configures the I2C target digital glitch filters for SCL input.</p> <p>Writing 0 to this field disables the glitch filter.</p> <p>Glitches equal to or less than the number of cycles defined by this field are filtered out and ignored.</p> <p>The latency through the glitch filter is equal to the number of cycles defined by this field + 3. The latency must be configured to be less than the minimum SCL low or high period.</p> <p><a href="#">MCFGR1[PRESCALE]</a> does not affect the glitch filter cycle count, and the glitch filter cycle count is disabled in HS mode.</p> |
| 15-14<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 13-8<br>DATAVD | <p>Data Valid Delay</p> <p>Configures the SDA data valid delay time for the I2C target, which is equal to FILTSCL + DATAVD + 3 cycles.</p> <p>The data valid delay must be configured to be less than the minimum SCL low period.</p> <p><a href="#">MCFGR1[PRESCALE]</a> does not affect the I2C target data valid delay time, and the I2C target data valid delay time is disabled in HS mode.</p>                                                                                                                                                                                          |
| 7-4<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3-0<br>CLKHOLD | <p>Clock Hold Time</p> <p>Configures the minimum clock hold time for the I2C target, when clock stretching is enabled.</p> <p>The minimum hold time is equal to the number of cycles defined by this field + 3.</p> <p><a href="#">MCFGR1[PRESCALE]</a> does not affect the I2C target clock hold time, and the I2C target clock hold time is disabled in HS mode.</p>                                                                                                                                                                                                                        |

### 36.7.1.27 Target Address Match (SAMR)

#### Offset

| Register | Offset |
|----------|--------|
| SAMR     | 140h   |

#### Function

Contains address values for received target match comparison.

Write to this register only when the I2C target is disabled.

**Diagram**

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

**Fields**

| Field          | Function                                                                                                                                                                                                                                                                                                                                                 |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-27<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                 |
| 26-17<br>ADDR1 | <p><b>Address 1 Value</b></p> <p>Contains the value of address 1, which is compared to the received address to detect the target address.</p> <p>In 10-bit mode, the first address byte is compared to {11110, ADDR1[26:25]} and the second address byte is compared to ADDR1[24:17].</p> <p>In 7-bit mode, the address is compared to ADDR1[23:17].</p> |
| 16-11<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                 |
| 10-1<br>ADDR0  | <p><b>Address 0 Value</b></p> <p>Contains the value of address 0, which is compared to the received address to detect the target address.</p> <p>In 10-bit mode, the first address byte is compared to {11110, ADDR0[10:9]} and the second address byte is compared to ADDR0[8:1].</p> <p>In 7-bit mode, the address is compared to ADDR0[7:1].</p>      |
| 0<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                 |

**36.7.1.28 Target Address Status (SASR)****Offset**

| Register | Offset |
|----------|--------|
| SASR     | 150h   |

**Function**

Contains the received address and its validity.

**Diagram**

| Bits  | 31 | 30         | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19           | 18 | 17 | 16 |
|-------|----|------------|----|----|----|----|----|----|----|----|----|----|--------------|----|----|----|
| R     |    |            |    |    |    |    |    |    | 0  |    |    |    |              |    |    |    |
| W     |    |            |    |    |    |    |    |    |    |    |    |    |              |    |    |    |
| Reset | 0  | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0            | 0  | 0  | 0  |
| Bits  | 15 | 14         | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3            | 2  | 1  | 0  |
| R     | 0  | <b>ANV</b> |    | 0  |    |    |    |    |    |    |    |    | <b>RADDR</b> |    |    |    |
| W     |    |            |    |    |    |    |    |    |    |    |    |    |              |    |    |    |
| Reset | 0  | 1          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0            | 0  | 0  | 0  |

**Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-15<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 14<br>ANV     | <p>Address Not Valid</p> <p>Indicates whether <a href="#">SASR[RADDR]</a> is valid.</p> <p>0b - Valid</p> <p>1b - Not valid</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 13-11<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 10-0<br>RADDR | <p>Received Address</p> <p>Contains the received address. Updates whenever <a href="#">SSR[AM0F]</a> or <a href="#">SSR[AM1F]</a> is set. Reading <a href="#">Target Address Status (SASR)</a> clears SSR[AM0F] and SSR[AM1F].</p> <p>In 7-bit mode, the address byte is stored in RADDR[7:0].</p> <p>In 10-bit mode, the first address byte is {11110, RADDR[10:9], RADDR[0]} and the second address byte is RADDR[8:1]. The Read-or-Write bit is therefore always stored in RADDR[0].</p> <p>When <a href="#">SCFGR1[ACKSTALL]</a> = 1, if the first address byte matches in 10-bit mode, the first address byte is stored in RADDR[7:0] so you can read this field before writing the Transmit ACK. If the second address byte matches, this field is then updated with the full 10-bit address.</p> |

### 36.7.1.29 Target Transmit ACK (STAR)

#### Offset

| Register | Offset |
|----------|--------|
| STAR     | 154h   |

#### Function

Configures choice of ACK or NACK on each received word.

You can write to this register only when [SCFGR1\[ACKSTALL\]](#) = 1.

[SCFGR1\[ACKSTALL\]](#) enables clock stretching during the ACK-or-NACK bit slot. During this time, you can write to this register.

The logic ensures that the clock stretching continues for at least one bus clock cycle after this register is updated.

This clock stretching time can be extended via [SCFGR2\[CLKHOLD\]](#).

#### Diagram

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

#### Fields

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-1<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0<br>TXNACK | <p>Transmit NACK</p> <p>Selects whether transmit ACK (logic 0) or NACK (logic 1) is returned on the bus by the I2C target after receiving each word.</p> <ul style="list-style-type: none"> <li>When <a href="#">SCFGR1[ACKSTALL]</a> = 1, a transmit NACK signal must be written once for each matching address byte and each received word. SCFGR1[ACKSTALL] must be 1, because that setting stalls the data transfer until software reads the received word (and determines whether to respond with an ACK or NACK).</li> <li>To configure the default (ACK or NACK), you can write to this field when LPI2C target is disabled or idle.</li> </ul> <p>0b - Transmit ACK<br/>1b - Transmit NACK</p> |

### 36.7.1.30 Target Transmit Data (STDR)

#### Offset

| Register | Offset |
|----------|--------|
| STDR     | 160h   |

#### Function

Contains the I2C target data to transmit.

Clock stretching (enabled or disabled) affects when the transmit data is transferred. [SCFGR1\[TXDSTALL\]](#) enables clock stretching during the first data bit of a target-transmit transfer.

If clock stretching is enabled ([SCFGR1\[TXDSTALL\]](#) = 1), the transmit data transfer is stalled until this register is updated. Clock stretching is extended by at least 1 bus clock cycle after this register is updated. Clock stretching can be delayed further by using [SCFGR2\[CLKHOLD\]](#).

If clock stretching is disabled ([SCFGR1\[TXDSTALL\]](#) = 0), the transmit data must be written before the start of the target-transmit transfer, otherwise [SSR\[FEF\]](#) is set.

#### Diagram



#### Fields

| Field       | Function                                                                                                                                   |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8<br>—   | Reserved                                                                                                                                   |
| 7-0<br>DATA | Transmit Data<br>Contains the I2C target data to transmit. Writing data to this register stores I2C target transmit data in this register. |

### 36.7.1.31 Target Receive Data (SRDR)

#### Offset

| Register | Offset |
|----------|--------|
| SRDR     | 170h   |

#### Function

Contains status of target receive data transfer.

#### Diagram



#### Fields

| Field         | Function                                                                                                                                              |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—    | Reserved                                                                                                                                              |
| 15<br>SOF     | Start of Frame<br>Indicates whether this data word is the first data word since a (repeated) Start or Stop condition.<br>0b - Not first<br>1b - First |
| 14<br>RXEMPTY | Receive Empty<br>Indicates whether this register is empty.<br>0b - Not empty<br>1b - Empty                                                            |
| 13-11<br>—    | Reserved                                                                                                                                              |
| 10-8          | Received Address                                                                                                                                      |

Table continues on the next page...

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RADDR       | Contains the address received by the I2C target. When both <a href="#">SCFGR1[RXCFG]</a> and <a href="#">SSR[AVF]</a> are 1, bits [10:8] of <a href="#">SASR[RADDR]</a> are returned. Otherwise, this field returns zero. |
| 7-0<br>DATA | Received Data<br>Contains the data received by the I2C target. When both <a href="#">SCFGR1[RXCFG]</a> and <a href="#">SSR[AVF]</a> are 1, bits [7:0] of <a href="#">SASR[RADDR]</a> are returned.                        |

### 36.7.1.32 Target Receive Data Read Only (SRDROR)

#### Offset

| Register | Offset |
|----------|--------|
| SRDROR   | 178h   |

#### Function

Contains the data received by the I2C target.

Reading this register returns the data received by the I2C target, but does not pull the data from the register.

#### Diagram



#### Fields

| Field      | Function                                                                                                              |
|------------|-----------------------------------------------------------------------------------------------------------------------|
| 31-16<br>— | Reserved                                                                                                              |
| 15<br>SOF  | Start of Frame<br>Indicates whether this data word is the first data word since a (repeated) Start or Stop condition. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                       |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | 0b - Not the first<br>1b - First                                                                                                                                                                                                               |
| 14<br>RXEMPTY | Receive Empty<br>Indicates whether <a href="#">Target Receive Data (SRDR)</a> is empty.<br>0b - Not empty<br>1b - Empty                                                                                                                        |
| 13-11<br>—    | Reserved                                                                                                                                                                                                                                       |
| 10-8<br>RADDR | Received Address<br>Contains address received by the LPI2C target.<br>When both <a href="#">SCFGR1[RXCFG]</a> and <a href="#">SSR[AVF]</a> are 1, bits [10:8] of <a href="#">SASR[RADDR]</a> are returned. Otherwise, this field returns zero. |
| 7-0<br>DATA   | Receive Data<br>Contains data received by the LPI2C target.<br>When both <a href="#">SCFGR1[RXCFG]</a> and <a href="#">SSR[AVF]</a> are 1, bits [7:0] of <a href="#">SASR[RADDR]</a> are returned.                                             |

# Chapter 37

## Low Power Universal Asynchronous Receiver/ Transmitter (LPUART)

### 37.1 Chip-specific LPUART information

Table 210. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | LPUART         | <a href="#">LPUART</a>              |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 37.1.1 Module instances

This device supports three instances of LPUART: LPUART0 to LPUART2.

### 37.2 Overview

LPUART provides asynchronous, serial communication capabilities with external devices. It supports the non-return-to-zero (NRZ) encoding format and infrared data association (IrDA)-compatible, low-speed serial infrared (SIR) protocol. LPUART can continue operating when the processor is in Low-Power mode, if an appropriate peripheral clock is available.

#### 37.2.1 Block diagram

[Figure 162](#) shows the transmitter portion of LPUART.



Figure 162. Transmitter block diagram

Figure 163 shows the receiver portion of LPUART.



### 37.2.2 Features

- Full-duplex, standard NRZ format
- Programmable baud rates (13-bit modulo divider) with a configurable oversampling ratio (OSR) from 4 $\times$  to 32 $\times$
- Asynchronous operation of transmit and receive baud rates with respect to the bus clock:
  - Baud rate can be configured independently of the bus clock frequency.
  - Operation in Low-Power modes is supported.
- Interrupt, DMA, or polled operations:
  - Transmit data empty and transmission complete
  - Receive data full
  - Receive overrun, parity error, framing error, and noise error
  - Idle receiver detect
  - Active edge on receive pin
  - Break detect supporting LIN
  - Receive data match
- Hardware parity generation and checking
- Programmable 7-bit, 8-bit, 9-bit, or 10-bit character length
- Programmable 1-bit or 2-bit stop bits
- Support for three receiver wake-up methods:
  - Idle line wake-up

- Address mark wake-up
- Receive data match
- Automatic address matching to reduce ISR overhead:
  - Address mark matching
  - Idle line address matching
  - Address match start, address match end
- Optional 13-bit and 11-bit break character generation
- Configurable idle length detection supporting 1, 2, 4, 8, 16, 32, 64, or 128 idle characters
- Selectable transmitter output and receiver input polarity
- Hardware flow control support for request to send (RTS) and clear to send (CTS) signals
- Selectable IrDA 1.4 return-to-zero-inverted (RZI) format with a programmable pulse width
- Independent FIFO structure for transmit and receive functions:
  - Separate configurable watermarks for receive and transmit requests
  - Option for receiver to assert request after a configurable number of idle characters, if receive FIFO is not empty

### 37.3 Functional description

LPUART supports full-duplex, asynchronous, NRZ serial communication and comprises a baud rate generator, transmitter, and receiver block. The transmitter and receiver operate independently, although they use the same baud rate generator. The following sections describe all LPUART blocks.

#### 37.3.1 Baud rate generation

A 13-bit modulus counter in the baud rate generator derives the baud rate for both the receiver and transmitter. The value, ranging from 1 to 8191, written to **BAUD[SBR]** determines the baud clock divisor for the asynchronous LPUART baud clock. The baud rate clock drives the receiver, while a bit clock, generated from the baud rate clock divided by the OSR, drives the transmitter. Depending on the OSR, the receiver has an acquisition rate of 4 to 32 samples per bit time.



Figure 164. Baud rate generation

Baud rate generation is subject to these sources of error:

- Integer division of the asynchronous LPUART baud clock may not give the exact target frequency.
- Synchronization with the asynchronous LPUART baud clock can lead to a phase shift.

Baud rate generation is a free-running counter that continues whenever the transmitter or receiver is enabled. The transmitter bit clock continues whenever the transmitter is enabled; each transmitted character aligns to the next edge of the transmit bit clock.

In general, configuring OSR for a higher ratio and/or sampling on both edges of the clock slightly improves LPUART's tolerance to baud rate mismatch between the received data and LPUART configured baud rate. However, the three data samples in each bit (see [Data sampling technique](#)) are also closer together, which may impact noise sensitivity.

### 37.3.2 Transmitter functional description

This section describes the functioning of the LPUART transmitter, as shown in the transmitter portion of [Block diagram](#), as well as specialized functions for sending break and idle characters.

The transmitter output (TXD) idle state defaults to logic high; the transmitter output is inverted when you write 1 to [CTRL\[TXINV\]](#), which becomes 0 following reset. You can enable the transmitter by writing 1 to [CTRL\[TE\]](#). This queues a preamble character that is one full character frame of the Idle state. The transmitter then remains idle until data is available in the transmit FIFO and programs store data in the transmit FIFO by writing to [Data \(DATA\)](#).

The central element of the LPUART transmitter is the transmit shift register that is 9-bit to 13-bit long depending on the settings of [CTRL\[M\]](#), [CTRL\[M7\]](#), [BAUD\[M10\]](#), and [BAUD\[SBNS\]](#). Going forward in this discussion, assume that [CTRL\[M\]](#), [CTRL\[M7\]](#), [BAUD\[M10\]](#), and [BAUD\[SBNS\]](#) are 0, selecting the normal 8-bit Data mode, in which the shift register holds a start bit, eight data bits, and a stop bit. When the transmit shift register is available for a new character, the value waiting in transmit FIFO is transferred to the transmit shift register, synchronized with the baud rate clock, and [STAT\[TDRE\]](#) becomes 1 to indicate that another character may be written to the transmit FIFO at [Data \(DATA\)](#).

If no new character is waiting in the transmit FIFO after a stop bit is shifted out of the TXD pin, the transmitter sets the transmit complete flag and enters an idle mode, with TXD high, waiting for more characters to transmit.

Writing 0 to [CTRL\[TE\]](#) does not immediately disable the transmitter. The current transmit activity in progress must first be completed (that could include a data character, idle character, or break character), although the transmitter does not start transmitting another character.

#### 37.3.2.1 Break character length

[CTRL\[SBK\]](#) sends break characters, originally used to gain the attention of old teletype receivers. Break characters are a full character time of logic 0, 9-bit to 12-bit times, including the start and stop bits. You can enable a longer break of 13-bit times by writing 1 to [STAT\[BRK13\]](#). Normally, a program waits for [STAT\[TDRE\]](#) to become 1 to indicate that the last character of a message has moved to the transmit shifter. Next, the program writes 1 and then writes 0 to [CTRL\[SBK\]](#). This action queues a break character to be sent as soon as the shifter is available. If [CTRL\[SBK\]](#) remains 1 when the queued break moves into the shifter, synchronized with the baud rate clock, an additional break character is queued. When LPUART is the receiving module, it receives a break character as 0s in all data bits and a framing error ([STAT\[FE\]](#) = 1) is detected.

You can also transmit a break character by writing to [Data \(DATA\)](#) with [DATA\[FRETSC\]](#) = 1 and the data bits clear. This supports transmitting the break character as part of the normal data stream and also allows DMA to transmit a break character.

When idle line wake-up is used, a full character time of idle (logic 1) is needed between messages to wake up any sleeping receivers. Normally, a program waits for [STAT\[TDRE\]](#) to become 1 to indicate that the last character of a message has moved to the transmit shifter. Next, write 0 and then write 1 to [CTRL\[TE\]](#). This action queues an idle character to be sent as soon as the shifter is available. As long as the character in the shifter does not finish while [CTRL\[TE\]](#) becomes 0, the LPUART transmitter does not release control of the TXD pin.

You can also write to [Data \(DATA\)](#) to transmit an idle character, with [DATA\[FRETSC\]](#) and [DATA\[R9T9\]](#) = 1 and the values of all the other fields = 0. This supports transmitting the idle character as part of the normal data stream and also allows DMA to transmit an idle character.

As shown in the following table, [STAT\[BRK13\]](#), [CTRL\[M\]](#), [CTRL\[M7\]](#), [BAUD\[M10\]](#), and [BAUD\[SBNS\]](#) affect the length of the break character.

Table 211. Break character length

| STAT[BRK13] | CTRL[M] | BAUD[M10] | CTRL[M7] | BAUD[SBNS] | Break character length (in bit times) |
|-------------|---------|-----------|----------|------------|---------------------------------------|
| 0           | 0       | 0         | 0        | 0          | 10                                    |
| 0           | 0       | 0         | 0        | 1          | 11                                    |
| 0           | 0       | 0         | 1        | 0          | 9                                     |
| 0           | 0       | 0         | 1        | 1          | 10                                    |
| 0           | 1       | 0         | —        | 0          | 11                                    |
| 0           | 1       | 0         | —        | 1          | 12                                    |
| 0           | —       | 1         | —        | 0          | 12                                    |
| 0           | —       | 1         | —        | 1          | 13                                    |
| 1           | 0       | 0         | 0        | 0          | 13                                    |
| 1           | 0       | 0         | 0        | 1          | 13                                    |
| 1           | 0       | 0         | 1        | 0          | 12                                    |
| 1           | 0       | 0         | 1        | 1          | 12                                    |
| 1           | 1       | 0         | —        | 0          | 14                                    |
| 1           | 1       | 0         | —        | 1          | 14                                    |
| 1           | —       | 1         | —        | 0          | 15                                    |
| 1           | —       | 1         | —        | 1          | 15                                    |

### 37.3.2.2 Hardware flow control

The transmitter supports hardware flow control by gating the transmission with the value of CTS\_B. If the CTS operation is enabled, the character is transmitted when CTS\_B is asserted. If CTS\_B is deasserted in the middle of a transmission with characters remaining in the transmitter FIFO, the character in the transmit shift register is complete. Any characters in the FIFO wait for CTS\_B to assert again, and TXD remains in the mark state (idle state) until CTS\_B is reasserted. The CTS\_B pin must assert for longer than one bit period to guarantee that a new transmission is started when the transmitter is idle with DTS.

If the CTS operation is disabled, the transmitter ignores the state of CTS\_B.

The transmitter's CTS\_B signal can be enabled even if the same LPUART receiver's RTS\_B signal is disabled.

### 37.3.2.3 Transceiver driver enable

The transmitter can use RTS\_B as an enable signal for the driver of an external transceiver. See [Transceiver driver enable using RTS\\_B](#) for details. If the RTS operation is enabled, when a character is placed into an empty transmit shift register, RTS\_B asserts 1-bit time before the start bit is transmitted. RTS\_B remains asserted for the whole time that the transmit shift register has any characters. RTS\_B deasserts 1-bit time after all characters in the transmit FIFO and shift register are completely sent, including the last stop bit. In other words, when RTS\_B is used as a transceiver enable, RTS\_B asserts 1-bit time before the transmitter starts transmitting and negates 1-bit time after the transmitter goes idle.

Transmitting a break character also asserts RTS\_B, with the same assertion and deassertion timing as having a character in the transmit shift register.

The transmitter's RTS\_B signal asserts only when the transmitter is enabled. However, the transmitter's RTS\_B signal is unaffected by its CTS\_B signal. RTS\_B remains asserted until the transfer is complete, even if the transmitter is disabled mid-way through a data transfer.

### 37.3.2.4 Transceiver driver enable using RTS\_B

RS-485 is a multiple drop communication protocol in which the LPUART transceiver's driver is three-stated unless LPUART is driving. The transmitter can use the RTS\_B signal to enable the driver of a transceiver. The polarity of RTS\_B can be matched to the polarity of the transceiver's driver enable signal.

The following figure shows the receiver enable signal asserted. This connection can also connect RTS\_B to both DE and RE\_B. The transceiver's receiver is disabled when driving. A pullup can pull RXD to a nonfloating value during this time. You can refine this option further by operating LPUART in Single-Wire mode, freeing the RXD pin for other uses.



Figure 165. Transceiver driver enable using RTS\_B

### 37.3.3 Receiver functional description

This section discusses the functioning of the LPUART receiver, as shown in the receiver portion of [Block diagram](#). The section also discusses:

- The data sampling technique used to reconstruct receiver data.
- Different variations of the receiver wake-up function.

You can invert the receiver input by writing 1 to [STAT\[RXINV\]](#) and enable the receiver by writing 1 to [CTRL\[RE\]](#). Character frames consist of a start bit of logic 0, seven to 10 data bits (MSB or LSB first), and one or two stop bits of logic 1. For information about 7-bit, 9-bit, or 10-bit Data mode, see [Data modes](#). Going forward in this discussion, assume that LPUART is configured for a normal 8-bit Data mode.

After receiving the stop bit into the receive shifter, and provided the receive data register is not already full ([STAT\[RDRF\]](#) = 0), the data character is transferred to the receive FIFO, resulting in [STAT\[RDRF\]](#) becoming 1. However, if [STAT\[RDRF\]](#) is already 1, indicating that the receive data buffer is already full, [STAT\[OR\]](#) becomes 1 and the new data is lost.

Because the LPUART receiver is separate from the receive FIFO, the receive shift register can receive the next word when the receive FIFO is full, and it is only at the end of the character that the next data is written into the receive FIFO, potentially triggering the overrun flag if the FIFO is full.

When a program detects that the receive data register is full ([STAT\[RDRF\]](#) = 1), it gets the data from the FIFO by reading [Data \(DATA\)](#). See [Interrupts](#) for details about flag clearing.

#### 37.3.3.1 Data sampling technique

The LPUART receiver supports a configurable oversampling rate of between 4 $\times$  and 32 $\times$  of the baud rate clock for sampling. The receiver starts by considering logic level samples at the oversampling rate times the baud rate to search for a falling edge on the RXD serial data input pin. A falling edge is defined as a logic 0 sample after three consecutive logic 1 samples. The oversampling baud rate clock divides the bit time into 4 to 32 segments from 1 to OSR (where OSR is the configured oversampling ratio). When a falling edge is located, three more samples are taken at  $(OSR \div 2)$ ,  $(OSR \div 2) + 1$ , and  $(OSR \div 2) + 2$  to ensure that this is a real start bit and not merely noise. If at least two of these three samples are 0, the receiver assumes they are synchronized to a received character. If another falling edge is detected before the receiver is considered synchronized, the receiver restarts sampling from the first segment.

The receiver then samples each bit time, including the start and stop bits, at  $(\text{OSR} \div 2)$ ,  $(\text{OSR} \div 2) + 1$ , and  $(\text{OSR} \div 2) + 2$ , to determine the logic level for that bit. The logic level is interpreted to be that of the majority of the samples taken during the bit time. If any sample in any bit time, including the start and stop bits, in a character frame fails to agree with the logic level for that bit, noise flag (**STAT[NF]**) becomes 1 when the received character is transferred to the receive FIFO.

When the LPUART receiver is configured to sample on both edges of the baud rate clock (that is, when **BAUD[BOTHEDGE]** = 1), the number of segments in each received bit is effectively doubled (from 1 to  $\text{OSR} \times 2$ ). The start and data bits are then sampled at  $\text{OSR}$ ,  $\text{OSR} + 1$ , and  $\text{OSR} + 2$ . You must enable sampling on both edges of the clock for oversampling rates of  $4\times$  to  $7\times$ . This sampling is optional for higher oversampling rates.

The synchronization feature of LPUART synchronizes the internal oversampling counter with a detected falling edge on the receive signal, and to adjust the data sampling window. The falling edge detection needs three consecutive 1s prior to the "1->0" (one to zero) transition. After the initial falling edge detection for the start bit, the circuit continuously monitors the next falling edge, and resets the counter after another falling edge is detected. This is called resynchronization.

When **BAUD[RESYNCDIS]** is 0, you perform this falling edge detection and resynchronization not only for the start bit but also for the rest of the character reception after the start bit.

When **BAUD[RESYNCDIS]** is 1, you perform the falling edge detection and resynchronization only for the start bit. The use case for disabling the resynchronization is protocols that require this (for example, LIN 2.1 prohibits resynchronization within a byte).

The following table and figure explain LPUART resynchronization.

Table 212. LPUART resynchronization settings

| Resynchronization                         | <b>BAUD[RESYNCDIS]</b> = 0 | <b>BAUD[RESYNCDIS]</b> = 1 |
|-------------------------------------------|----------------------------|----------------------------|
| For the starting bit falling edge         | Yes                        | Yes                        |
| For all falling edges after the start bit | Yes                        | No                         |



Figure 166. LPUART resynchronization diagram

### 37.3.3.2 Receiver wake-up operation

Receiver wake-up and receiver address matching are hardware mechanisms that allow an LPUART receiver to ignore the characters in a message intended for a different receiver.

During receiver wake-up, all receivers evaluate the first character(s) of each message, and as soon as they determine the message is intended for a different receiver, they write 1 to **CTRL[RWU]**.

When **CTRL[RWU]** and **STAT[RWUID]** are 1, the status fields associated with the receiver, with the exception of **STAT[IDLE]**, are inhibited from becoming 1, thus eliminating the software overhead for handling the unimportant message characters. At the end of a message, all receivers automatically force **CTRL[RWU]** to become 0. This results in all receivers waking up in time to look at the first character(s) of the next message.

During receiver address matching, the address matching is performed in hardware and the LPUART receiver ignores all characters that do not meet the address match requirements.

Table 213. Receiver wake-up options

| <b>CTRL[RWU]</b> | <b>BAUD[MAEN1]   BAUD[MAEN2]</b> | <b>BAUD[MATCFG]</b> | <b>CTRL[WAKE]: STAT[RWUID]</b> | Receiver wake-up                                                           |
|------------------|----------------------------------|---------------------|--------------------------------|----------------------------------------------------------------------------|
| 0                | 0                                | X                   | X                              | Normal operation                                                           |
| 1                | 0                                | 00                  | 00                             | Receiver wake-up on idle line; <b>STAT[IDLE]</b> = 0                       |
| 1                | 0                                | 00                  | 01                             | Receiver wake-up on idle line; <b>STAT[IDLE]</b> = 1                       |
| 1                | 0                                | 00                  | 10                             | Receiver wake-up on address mark                                           |
| 1                | 1                                | 11                  | 10                             | Receiver wake-up on data match                                             |
| 0                | 1                                | 00                  | X0                             | Address mark address match; <b>STAT[IDLE]</b> = 0 for discarded characters |
| 0                | 1                                | 00                  | X1                             | Address mark address match; <b>STAT[IDLE]</b> = 1 for discarded characters |
| 0                | 1                                | 01                  | X0                             | Idle line address match                                                    |
| 0                | 1                                | 10                  | X0                             | Match on and match off; <b>STAT[IDLE]</b> = 0 for discarded characters     |
| 0                | 1                                | 10                  | X1                             | Match on and match off; <b>STAT[IDLE]</b> = 1 for discarded characters     |

#### 37.3.3.2.1 Idle line wake-up

When **CTRL[WAKE]** is 0, you can configure the receiver for an idle line wake-up. In this mode, **CTRL[RWU]** becomes 0 automatically when the receiver detects a full character time of the idle-line level.

**CTRL[M]**, **CTRL[M7]**, and **BAUD[M10]** select 7-bit to 10-bit Data mode and **BAUD[SBNS]** selects a 1-bit or 2-bit stop bit number that determines how many bit times of idle are needed to constitute a full character time, 9 to 13 bit times because of the start and stop bits.

When **CTRL[RWU]** is 1 and **STAT[RWUID]** is 0, the idle condition that wakes up the receiver does not lead to **STAT[IDLE]** becoming 1. The receiver wakes up and waits for the first data character of the next message that leads to **STAT[RDRF]** becoming 1 and generates an interrupt if enabled. When **STAT[RWUID]** is 1, any idle condition leads to **STAT[IDLE]** becoming 1 and generates an interrupt if enabled, regardless of whether **CTRL[RWU]** is 0 or 1.

These are the ways to detect an idle line:

- When **CTRL[ILT]** is 0, the idle bit counter starts after the start bit so that the stop bit and any logic 1s at the end of a character count to calculate the full character time of idle.
- When **CTRL[ILT]** is 1, the idle bit counter does not start until after the stop bit time so that the data in the last character of the previous message does not impact the idle detection.

### 37.3.3.2.2 Address mark wake-up

When **CTRL[WAKE]** is 1, you can configure the receiver for an address mark wake-up. In this mode, **CTRL[RWU]** becomes 0 automatically when the receiver detects a logic 1 in the most significant bit of the received character. When parity is enabled, the second most significant bit is used for address mark wake-up.

Address mark wake-up allows messages to contain idle characters, but requires one bit to be reserved for use in address frames. The logic 1 in the most significant bit (or second most significant bit when parity is enabled) of an address frame writes 0 to **CTRL[RWU]** and writes 1 to **STAT[RDRF]**. In this case, the character with the address mark bit is received even if the receiver is sleeping during most of this character time.

### 37.3.3.2.3 Data match wake-up

When **CTRL[RWU]** and **CTRL[WAKE]** are 1, and **BAUD[MATCFG]** equals 11, the receiver is configured for a data match wake-up. In this mode, **CTRL[RWU]** becomes 0 automatically when the receiver detects a character that matches **MATCH[MA1]** when **BAUD[MAEN1]** is 1, or that matches **MATCH[MA2]** when **BAUD[MAEN2]** is 1.

### 37.3.3.2.4 Address match operation

You can enable the address match operation when either **BAUD[MAEN1]** or **BAUD[MAEN2]** is 1 and **BAUD[MATCFG]** is 0. In this function, a character that the RXD pin receives with a logic 1 in the most significant bit (or the second most significant bit when parity is enabled) is considered an address and is compared to the associated **MATCH[MA1]** or **MATCH[MA2]**. The character is only transferred to the receive buffer, and **STAT[RDRF]** becomes 1 if the comparison matches. All subsequent characters received with a logic 0 in the most significant bit (or the second most significant bit when parity is enabled) are considered to be data associated with the address and are transferred to the receive FIFO. If no marked address match occurs, no transfer is made to the receive FIFO, and all the characters that follow, with logic 0 in the most significant bit (or second most significant bit when parity is enabled), are also discarded. If both **BAUD[MAEN1]** and **BAUD[MAEN2]** are 0, the receiver operates normally, and all the received data is transferred to the receive FIFO.

The address match operation functions in the same way for both **MATCH[MA1]** and **MATCH[MA2]**:

- If either **BAUD[MAEN1]** or **BAUD[MAEN2]** is 1, a marked address is compared only to the associated **Match Address (MATCH)** and data is transferred to the receive FIFO only on a match.
- If both **BAUD[MAEN1]** and **BAUD[MAEN2]** are 1, a marked address is compared to both **MATCH[MA1]** and **MATCH[MA2]** and data is transferred only on a match with either of these fields.

### 37.3.3.2.5 Idle match operation

You can enable the idle match operation when either **BAUD[MAEN1]** or **BAUD[MAEN2]** is 1 and **BAUD[MATCFG]** is 1. In this function, the first character that the RXD pin receives after an idle line condition is considered an address and is compared to the associated **MATCH[MA1]** or **MATCH[MA2]**. The character is transferred only to the receive buffer, and **STAT[RDRF]** becomes 1, if the comparison matches. All subsequent characters are considered to be data associated with the address and are transferred

to the receive FIFO until the next idle line condition is detected. If no address match occurs, no transfer is made to the receive FIFO, and all the frames that follow, until the next idle condition, are also discarded. If both **BAUD[MAEN1]** and **BAUD[MAEN2]** are 0, the receiver operates normally, and all the received data is transferred to the receive FIFO.

An idle match operation functions in the same way for both **MATCH[MA1]** and **MATCH[MA2]**:

- If either **BAUD[MAEN1]** or **BAUD[MAEN2]** is 1, the first character after an idle line is compared only to the associated **Data (DATA)** and data is transferred to the receive FIFO only on a match.
- If both **BAUD[MAEN1]** and **BAUD[MAEN2]** are 1, the first character after an idle line is compared to both **MATCH[MA1]** and **MATCH[MA2]** and data is transferred only on a match with either of these fields.

### 37.3.3.2.6 Match on, match off operation

The match on, match off operation is enabled when both **BAUD[MAEN1]** and **BAUD[MAEN2]** are 1 and **BAUD[MATCFG] = 10**. In this function, a character that the RXD pin receives matches **MATCH[MA1]** and is transferred to the receive buffer, and **STAT[RDRF]** becomes 1. All subsequent characters are considered to be data and are also transferred to the receive FIFO, until a character that matches **MATCH[MA2]** is received. The character that matches **MATCH[MA2]**, along with all subsequent characters, is discarded; and this continues until another character that matches **MATCH[MA1]** is received. If both **BAUD[MAEN1]** and **BAUD[MAEN2]** are 0, the receiver operates normally, and all the received data is transferred to the receive FIFO.

#### NOTE

The match on, match off operation requires both **BAUD[MAEN1]** and **BAUD[MAEN2]** to be 1.

### 37.3.3.3 Hardware flow control

To support hardware flow control, you can program the receiver to automatically assert and deassert RTS\_B:

- RTS\_B remains asserted until the transfer is complete, even if the transmitter is disabled midway through a data transfer. See [Transceiver driver enable using RTS\\_B](#) for more information.
- If the receiver RTS functionality is enabled, the receiver automatically deasserts RTS\_B if **STAT[RDRF]** is 1 or a start bit is detected that causes **STAT[RDRF]** to become 1.
- The receiver asserts RTS\_B when **STAT[RDRF]** is 0 and has not detected a start bit that causes **STAT[RDRF]** to become 1. There is no impact if **STAT[RDRF]** is 1 already.
- Even if RTS\_B is deasserted, the receiver continues to receive characters until the receive FIFO is overrun.
- If the receiver RTS functionality is disabled, the receiver's RTS\_B remains deasserted.

### 37.3.4 Additional LPUART functions

#### 37.3.4.1 Data modes

You can configure the LPUART transmitter and receiver to operate in 7-bit Data mode by writing 1 to **CTRL[M7]**, 9-bit Data mode by writing 1 to **CTRL[M]**, or 10-bit Data mode by writing 1 to **BAUD[M10]**. In 9-bit Data mode, there exists a ninth data bit and in 10-bit mode, there exists a tenth data bit.

When performing 8-bit writes to the transmit FIFO, the ninth and tenth bits are pushed into the FIFO from **CTRL[T8]** and **CTRL[T9]**. For coherent 8-bit writes, you must write to **CTRL[T8]** and **CTRL[T9]** before writing to **Data (DATA)[7:0]**. However, if the values in **CTRL[T8]** or **CTRL[T9]** do not need to change, it is not necessary to update **CTRL[T8]** and **CTRL[T9]** before every 8-bit write to **Data (DATA)**.

When performing 16-bit or 32-bit writes to the transmit FIFO, all 10 bits are pushed into the transmit FIFO from the write data.

When performing 8-bit reads of the receive FIFO, the ninth and tenth bits are held in **CTRL[R8]** and **CTRL[R9]** but you must read them before reading **Data (DATA)**. A 16-bit or 32-bit read of the receive FIFO returns all 10 bits in **Data (DATA)**.

The 9-bit Data mode is typically used with parity to allow eight bits of data plus the parity in the ninth bit, or it is used with the address mark wake-up so that the ninth data bit can serve as the wake-up bit. The 10-bit Data mode is typically used with parity

and address mark wake-up so that the ninth data bit can serve as the wake-up bit and the tenth bit can serve as the parity bit. In custom protocols, the ninth and/or tenth bits can also serve as software-controlled markers.

### 37.3.4.2 Idle length

An idle character is one where the start bit, all data bits, and stop bits are in the mark position (idle state, generally logic 1). You can configure [CTRL\[ILT\]](#) to start detecting an idle character from the previous start bit (any data bits and stop bits count for idle character detection) or from the previous stop bit.

You can also use [CTRL\[IDLECFG\]](#) to configure the number of idle characters that must be received before an idle line condition is detected. This field configures the number of idle characters that must be received before [STAT\[IDLE\]](#) becomes 1, [STAT\[RAF\]](#) becomes 0, and [DATA\[IDLINE\]](#) becomes 1 with the next received character.

[CTRL\[IDLECFG\]](#) also affects the idle line wake-up and idle match operations. When either the address match or match on/off operation is enabled, writing 1 to [STAT\[RWUID\]](#) causes any discarded characters to be treated as idle characters.

### 37.3.4.3 Loop mode

When [CTRL\[LOOPS\]](#) is 1, [CTRL\[RSRC\]](#) selects between Loop mode ([CTRL\[RSRC\]](#) = 0) or Single-Wire mode ([CTRL\[RSRC\]](#) = 1). You, sometimes, use Loop mode to check software, independent of connections in the external system, to help isolate system problems. In this mode, the transmitter output is internally connected to the receiver input and LPUART does not use the RXD pin.

Loop mode also internally connects the RTS\_B output to the CTS\_B input.

### 37.3.4.4 Single-Wire mode

When [CTRL\[LOOPS\]](#) is 1, [CTRL\[RSRC\]](#) selects either Loop mode ([CTRL\[RSRC\]](#) = 0) or Single-Wire mode ([CTRL\[RSRC\]](#) = 1). Single-Wire mode implements a half-duplex serial connection. The receiver is internally connected to the transmitter output and TXD pin (the RXD pin is not used).

In Single-Wire mode, [CTRL\[TXDIR\]](#) controls the direction of serial data on the TXD pin. When [CTRL\[TXDIR\]](#) becomes 0, the TXD pin is an input to the receiver and the transmitter is temporarily disconnected from the TXD pin so that an external device can send serial data to the receiver. When [CTRL\[TXDIR\]](#) = 1, the TXD pin is an output that the transmitter drives. The internal loop back connection is disabled, and as a result, the receiver is unable to receive characters that the transmitter sends out.

## 37.3.5 Peripheral triggers

The connection of the LPUART peripheral triggers with other peripherals is chip-specific.

### 37.3.5.1 Output triggers

LPUART generates the following output triggers that can be connected to other peripherals on the chip:

- The transmit word trigger asserts at the end of each transmitted word and negates after 1-bit period.
- The transmit data trigger is identical to the TXD pin output, but without support for input trigger modulation.
- The receive word trigger asserts at the end of each received word that is written to the receive FIFO, for one oversampling clock period.
- The receive idle trigger asserts when [STAT\[IDLE\]](#) becomes 1, and negates when the next valid start bit is detected.

### 37.3.5.2 Input trigger

LPUART supports a peripheral input trigger that you can configure in one of the following ways:

- By enabling the CTS function: You can connect the input trigger instead of the CTS\_B pin input. The input trigger must assert for longer than 1-bit clock period when the transmitter is idle, with data to send, to guarantee a new transmission.
- By making the input trigger modulate the transmit data output (trigger is logically ANDed with the TXD output): The input trigger is expected to be a free-running clock (carrier signal) that generates from a timer or PWM source with a frequency that is greater than the bit-clock frequency. The carrier signal must not toggle faster than the maximum supported bit time.

- By connecting the input trigger instead of the RXD pin input: The input trigger is expected to be generated from a receive data source, such as an analog comparator or external pin.

### 37.3.6 Infrared (IR) interface

LPUART provides the capability of transmitting narrow pulses to an IR LED and receiving narrow pulses, transforming them to serial bits, which are then sent to LPUART. The IrDA physical layer specification defines a half-duplex IR communication link for exchanging data. The full standard includes data rates up to 16 Mbit/s. The LPUART IrDA support is limited to SIR mode that supports data rates only between 2.4 kbit/s and 115.2 kbit/s.

LPUART has an infrared transmit encoder and a receive decoder. The infrared decoder converts the received character from the IrDA format to the NRZ format, which the receiver uses. It also has an OSR oversampling baud rate clock counter that filters noise and indicates when a 1 is received. LPUART transmits serial bits of data, which the infrared submodule encodes, to transmit a narrow pulse for every zero bit. No pulse is transmitted for every single bit. When receiving data, an IR photo diode (external to LPUART) detects the IR pulses. The IR receive decoder transforms them to CMOS levels. The infrared receive decoder then stretches the narrow pulses to get back to a serial bit stream that LPUART receives. You can invert the polarity of transmitted pulses and expected receive pulses so that a direct connection can be made to external IrDA transceiver modules that use active-high pulses.

The IR submodule receives its clock sources from LPUART. The submodule selects one of these clocks to generate either  $1 \div \text{OSR}$ ,  $2 \div \text{OSR}$ ,  $3 \div \text{OSR}$ , or  $4 \div \text{OSR}$  narrow pulses during transmission.

#### 37.3.6.1 Infrared transmit encoder

The infrared transmit encoder converts serial bits of data from the transmit shift register to the TXD signal. A narrow pulse is transmitted for a 0 bit and no pulse is transmitted for a 1 bit. The narrow pulse is sent at the start of the bit with a duration of  $1 \div \text{OSR}$ ,  $2 \div \text{OSR}$ ,  $3 \div \text{OSR}$ , or  $4 \div \text{OSR}$  of a bit time. A narrow low pulse is transmitted for a 0 bit when [CTRL\[TXINV\]](#) is 0, while a narrow high pulse is transmitted for a 0 bit when [CTRL\[TXINV\]](#) is 1.

#### 37.3.6.2 Infrared receive decoder

The infrared receive block converts data from the RXD signal to the receive shift register. A narrow pulse is expected for each 0 received and no pulse is expected for each 1 received. A narrow low pulse is expected for a 0 bit when [STAT\[RXINV\]](#) is 0, while a narrow high pulse is expected for a 0 bit when [STAT\[RXINV\]](#) is 1. This receive decoder meets the edge jitter requirement as defined by the IrDA serial infrared physical layer specification.

#### 37.3.6.3 Start-bit detection

When [STAT\[RXINV\]](#) is 0, the first falling edge of the received character corresponds to the start bit. The infrared decoder resets its counter. At this time, the receiver also begins its start bit detection process. After the start bit is detected, the receiver synchronizes its bit times to this start bit time. For the rest of the character reception, the infrared decoder's counter and the receiver's bit time counter count independently of each other.

#### 37.3.6.4 Noise filtering

The decoder ignores any rising edges detected during the first half of the infrared decoder counter, and can leave any pulses less than one oversampling baud clock as undetected. This is regardless of whether the pulse is seen in the first or second half of the count.

#### 37.3.6.5 Low-bit detection

During the second half of the decoder count, a rising edge is decoded as 0, which is sent to the receiver. The decoder counter is also reset.

#### 37.3.6.6 High-bit detection

At OSR oversampling baud rate clocks after the previous rising edge, if a rising edge is not seen, the decoder sends a 1 to the receiver.

If the next bit is 0, which arrives late, a low bit is detected according to [Low-bit detection](#). The value sent to the receiver is changed from 1 to 0. Then, if a noise pulse occurs outside the receiver's bit time sampling period, the delay of a 0 is not recorded as noise.

### 37.3.7 Modes of operation

#### 37.3.7.1 Low-Power modes

LPUART remains functional during low-power modes, provided [CTRL\[DOZEEN\]](#) is 0 and the LPUART functional clock is enabled. LPUART can generate an interrupt or DMA request to cause a wake-up from low-power modes.

You can configure LPUART to be disabled in low-power modes, when [CTRL\[DOZEEN\]](#) is 1. In this case, the transmitter and receiver finish transmitting and receiving the current word.

If LPUART is disabled in low-power modes, it can generate a wake-up via [STAT\[RXEDGIF\]](#) if the receiver detects an active edge.

**NOTE**

See the chip-specific information for specific low-power modes available on your chip.

#### 37.3.7.2 Debug mode

LPUART remains functional in Debug mode.

### 37.3.8 Clocking

Table 214. Types of clocks

| Clock      | Description                                                                                                                                                                                                                        |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Functional | Is asynchronous to the bus clock and can remain enabled in Low-Power modes to support transmit and/or receive functions, including low-power wake-up.                                                                              |
| Bus        | Is only used for bus accesses to the control and configuration registers. The bus clock frequency must be sufficient to support the data bandwidth requirements of the LPUART transmit and receive registers, including the FIFOs. |

### 37.3.9 Reset

Table 215. Types of resets

| Reset    | Description                                                                                                                                                                                             |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Chip     | Enables the logic and registers for the LPUART transmitter and receiver to reset to their default states.                                                                                               |
| Software | Resets the LPUART logic and registers to their default states, except for <a href="#">Global (GLOBAL)</a> . <a href="#">GLOBAL[RST]</a> controls the LPUART software reset.                             |
| FIFO     | Implements write-only control fields that reset the transmit FIFO ( <a href="#">FIFO[TXFLUSH]</a> ) and receive FIFO ( <a href="#">FIFO[RXFLUSH]</a> ). After a FIFO is reset, that FIFO becomes empty. |

### 37.3.10 Interrupts

The LPUART transmitter has two status fields that can optionally generate hardware interrupt requests. If [STAT\[TDRE\]](#) is 1, it indicates that there is room in the transmit FIFO to write another transmit character to [Data \(DATA\)](#). If [CTRL\[TIE\]](#) is 1, a hardware interrupt is requested when [STAT\[TDRE\]](#) is 1.

[STAT\[TC\]](#) indicates that the transmitter is finished transmitting all data, preamble, and break characters and is idle with TXD at the inactive level. This field is often used in systems with modems to determine when it is safe to turn off the modem. If [CTRL\[TCIE\]](#) is

1, a hardware interrupt is requested when **STAT[TC]** is 1. Instead of hardware interrupts, software polling may be used to monitor **STAT[TDRE]** and **STAT[TC]** if the corresponding **CTRL[TIE]** or **CTRL[TCIE]** field is 0.

When a program detects that **STAT[RDRF]** is 1, it gets the data from this field by reading **Data (DATA)**. The field becomes 0 by reading **Data (DATA)**.

**STAT[IDLE]** includes logic that prevents it from becoming 1 repeatedly when the RXD line remains idle for an extended period of time. **STAT[IDLE]** becomes 0 when you write 1 to it, and cannot become 1 again until the receiver has received at least one new character and has 1 as the value of **STAT[RDRF]**.

If the associated error is detected in the received character that caused **STAT[RDRF]** to become 1, **STAT[NF]**, **STAT[FE]**, and **STAT[PF]** become 1 at the same time **STAT[RDRF]** becomes 1. These flags do not become 1 in overrun cases.

If **STAT[RDRF]** is already 1 when a new character is ready to be transferred from the receive shifter to the receive FIFO, **STAT[OR]** becomes 1, instead of the data along with any associated **STAT[NF]**, **STAT[FE]**, or **STAT[PF]** condition getting lost.

If the received character matches the contents of **MATCH[MA1]** and/or **MATCH[MA2]**, then **STAT[MA1F]** and/or **STAT[MA2F]** become 1 at the same time that **STAT[RDRF]** becomes 1.

At any time, an active edge on the RXD serial data input pin causes **STAT[RXEDGIF]** to become 1. **STAT[RXEDGIF]** becomes 0 when you write 1 to it. This function depends on the receiver being enabled (the value of **CTRL[RE]** being 1).

### 37.3.11 DMA

#### 37.3.11.1 End-of-packet DMA transfers

The end-of-packet functionality is designed for serial interfaces where you may not know the size of the transfer in advance and the data is being pushed by an external device. Examples include UART receive, I2C Slave mode, and SPI Slave mode. The end-of-packet processing ensures that data does not become stranded in either the receive FIFO or the DMA receive buffer. Support for end-of-packet processing must be implemented in both the serial interfaces and DMA controller.

The condition that signals the end of packet is different for each serial interface, but the serial peripheral and DMA process it in the same way. For example, an idle line condition signals the UART end of packet, the Stop and/or Repeated Start condition signals the I2C end of packet, and PCS negation signals the SPI end of packet.

When the serial peripheral is configured to signal the end-of-packet condition to the DMA and the serial interface detects an end-of-packet condition, it asserts the DMA request for the receive FIFO irrespective of the watermark configuration. For larger watermark configurations, this ensures that the last few words of the transfer are first flushed from the receive FIFO.

The DMA then reads the contents of the receive FIFO, depending on the first word in the FIFO:

- If the receive FIFO is empty, the serial interface signals an end of packet condition to the DMA controller.
- If the receive FIFO is not empty, but the first word in the FIFO is the start of a new packet, data is not pulled from the receive FIFO and the serial interface signals an end-of-packet condition to the DMA controller.
- If the receive FIFO is not empty, and the first word in the FIFO is not the start of a new packet, the DMA transfers the receive data as normal.

Because the DMA may be transferring multiple words on each request, the end-of-packet condition persists until the DMA minor loop has completed and no additional data is pulled from the receive FIFO. The field that triggered the end-of-packet condition becomes 0 when the minor loop completes following the end of packet being signaled to the DMA controller.

When the DMA detects the end-of-packet condition, it writes all received words up to the end of packet into the system memory and saves the destination address for the word after the last valid data. The DMA then terminates the channel as if the major loop completed, including final offsets and optional interrupts, channel linking, and scatter-gather. You can, optionally, save the final destination address to the system memory. The final destination address is also available in the destination address register.

Because the DMA terminates the major loop, no servicing of the receive FIFO occurs until you or the hardware reconfigures the DMA (for example, channel linking or scatter-gather). You must minimize this delay to avoid receiver FIFO overrun. The automatic DMA end-of-packet processing is not recommended when there are only a few words transferred between end-of-packet conditions. This is because the DMA spends more time processing the end of packet than transferring the data. For example, the UART idle line length must be increased as needed to avoid an excessive number of idle conditions.

## 37.4 External signals

Table 216. External signals

| Signal | Description                                                                                                                                                                                   | I/O |
|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| TXD    | Transmit data: This pin is normally an output, but is an input (tristated) in Single-Wire mode whenever the transmitter is disabled or the transmit direction is configured for receive data. | I/O |
| RXD    | Receive data                                                                                                                                                                                  | I   |
| CTS_B  | Clear-to-send                                                                                                                                                                                 | I   |
| RTS_B  | Request-to-send                                                                                                                                                                               | O   |

## 37.5 Initialization

This module does not require initialization.

## 37.6 Register definition

LPUART includes registers to control baud rate, select options, report status, and store transmit and receive data. Access to an address outside the valid memory map generates a bus error.

**NOTE**

Writing to a read-only (RO) register or reading a write-only (WO) register can cause bus errors. LPUART does not verify whether programmed values in the registers are correct; you must write valid values to them.

### 37.6.1 LPUART register descriptions

#### 37.6.1.1 LPUART memory map

LPUART0 base address: 4009\_F000h

LPUART1 base address: 400A\_0000h

LPUART2 base address: 400A\_1000h

| Offset | Register                   | Width<br>(In bits) | Access | Reset value |
|--------|----------------------------|--------------------|--------|-------------|
| 0h     | Version ID (VERID)         | 32                 | R      | 0404_0003h  |
| 4h     | Parameter (PARAM)          | 32                 | R      | 0000_0202h  |
| 8h     | Global (GLOBAL)            | 32                 | RW     | 0000_0000h  |
| Ch     | Pin Configuration (PINCFG) | 32                 | RW     | 0000_0000h  |
| 10h    | Baud Rate (BAUD)           | 32                 | RW     | 0F00_0004h  |
| 14h    | Status (STAT)              | 32                 | RW     | 00C0_0000h  |
| 18h    | Control (CTRL)             | 32                 | RW     | 0000_0000h  |
| 1Ch    | Data (DATA)                | 32                 | RW     | 0000_1000h  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset | Register                | Width<br>(In bits) | Access | Reset value |
|--------|-------------------------|--------------------|--------|-------------|
| 20h    | Match Address (MATCH)   | 32                 | RW     | 0000_0000h  |
| 24h    | MODEM IrDA (MODIR)      | 32                 | RW     | 0000_0000h  |
| 28h    | FIFO (FIFO)             | 32                 | RW     | 00C0_0011h  |
| 2Ch    | Watermark (WATER)       | 32                 | RW     | 0000_0000h  |
| 30h    | Data Read-Only (DATARO) | 32                 | R      | 0000_1000h  |

### 37.6.1.2 Version ID (VERID)

#### Offset

| Register | Offset |
|----------|--------|
| VERID    | 0h     |

#### Function

Indicates the version integrated for this instance on the chip and also specifies the inclusion and exclusion of several optional features.

#### Diagram

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

#### Fields

| Field          | Function                                                                                 |
|----------------|------------------------------------------------------------------------------------------|
| 31-24<br>MAJOR | Major Version Number<br>Indicates the major version number for the module specification. |
| 23-16          | Minor Version Number                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                     |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MINOR           | Indicates the minor version number for the module specification.                                                                                                                             |
| 15-0<br>FEATURE | Feature Identification Number<br>Indicates the feature set number.<br>0000_0000_0000_0001b - Standard feature set<br>0000_0000_0000_0011b - Standard feature set with MODEM and IrDA support |

### 37.6.1.3 Parameter (PARAM)

#### Offset

| Register | Offset |
|----------|--------|
| PARAM    | 4h     |

#### Function

Indicates the parameter configuration for this instance on the chip.

#### Diagram



#### Fields

| Field          | Function                                                                                                      |
|----------------|---------------------------------------------------------------------------------------------------------------|
| 31-16<br>—     | Reserved                                                                                                      |
| 15-8<br>RXFIFO | Receive FIFO Size<br>Indicates the number of characters in the receive FIFO, which is $2^{\text{RXFIFO}}$ .   |
| 7-0<br>TXFIFO  | Transmit FIFO Size<br>Indicates the number of characters in the transmit FIFO, which is $2^{\text{TXFIFO}}$ . |

### 37.6.1.4 Global (GLOBAL)

#### Offset

| Register | Offset |
|----------|--------|
| GLOBAL   | 8h     |

#### Function

Performs global functions.

#### Diagram



#### Fields

| Field     | Function                                                                                                                                                                                                                                                                                                                                                        |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2<br>— | Reserved                                                                                                                                                                                                                                                                                                                                                        |
| 1<br>RST  | <p>Software Reset</p> <p>Specifies whether the module is reset.</p> <p>This field resets all internal logic and registers, except <a href="#">Global (GLOBAL)</a>. The reset takes effect immediately and remains asserted until you negate it. There is no minimum delay required before clearing the software reset.</p> <p>0b - Not reset<br/>1b - Reset</p> |
| 0<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                        |

### 37.6.1.5 Pin Configuration (PINCFG)

#### Offset

| Register | Offset |
|----------|--------|
| PINCFG   | Ch     |

#### Function

Enables the selection of input pins.

#### Diagram



#### Fields

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1-0<br>TRGSEL | <p>Trigger Select</p> <p>Configures the input trigger usage.</p> <p>You must change the value of this field only when both the transmitter and receiver are disabled.</p> <ul style="list-style-type: none"> <li>00b - Input trigger disabled</li> <li>01b - Input trigger used instead of the RXD pin input</li> <li>10b - Input trigger used instead of the CTS_B pin input</li> <li>11b - Input trigger used to modulate the TXD pin output, which (after TXINV configuration) is internally ANDed with the input trigger</li> </ul> |

### 37.6.1.6 Baud Rate (BAUD)

#### Offset

| Register | Offset |
|----------|--------|
| BAUD     | 10h    |

#### Function

Configures the baud rate.

#### Diagram

| Bits  | 31    | 30       | 29   | 28  | 27 | 26 | 25 | 24    | 23 | 22    | 21     | 20     | 19 | 18        | 17          | 16 |
|-------|-------|----------|------|-----|----|----|----|-------|----|-------|--------|--------|----|-----------|-------------|----|
| R     | MAEN1 | MAEN2    | M10  | OSR |    |    |    | TDMAE | 0  | RDMAE | RIDMAE | MATCFG |    | BOTH EDGE | RESY NCD... |    |
| W     | 1     | 2        |      |     |    |    |    |       |    |       |        |        |    |           |             |    |
| Reset | 0     | 0        | 0    | 0   | 1  | 1  | 1  | 1     | 0  | 0     | 0      | 0      | 0  | 0         | 0           | 0  |
| Bits  | 15    | 14       | 13   | 12  | 11 | 10 | 9  | 8     | 7  | 6     | 5      | 4      | 3  | 2         | 1           | 0  |
| R     | LBKDI | RXED GIE | SBNS | SBR |    |    |    |       |    |       |        |        |    |           |             |    |
| W     | E     |          |      |     |    |    |    |       |    |       |        |        |    |           |             |    |
| Reset | 0     | 0        | 0    | 0   | 0  | 0  | 0  | 0     | 0  | 0     | 0      | 0      | 0  | 0         | 1           | 0  |

#### Fields

| Field       | Function                                                                                                                                                                                                                                                                                                                                     |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>MAEN1 | <p>Match Address Mode Enable 1</p> <p>Enables automatic address matching or data matching mode for <a href="#">MATCH[MA1]</a>. If this field is 0, normal operation takes place.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                     |
| 30<br>MAEN2 | <p>Match Address Mode Enable 2</p> <p>Enables automatic address matching or data matching mode for <a href="#">MATCH[MA2]</a>. If this field is 0, normal operation takes place.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                     |
| 29<br>M10   | <p>10-Bit Mode Select</p> <p>Causes the tenth bit to be a part of the serial transmission.</p> <p>You must change the value of this field only when both the transmitter and receiver are disabled.</p> <p>0b - Receiver and transmitter use 7-bit to 9-bit data characters<br/>1b - Receiver and transmitter use 10-bit data characters</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28-24<br>OSR | <p>Oversampling Ratio</p> <p>Configures the OSR of the receiver.</p> <p>You must change the value of this field only when both the transmitter and receiver are disabled.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>BAUD[OSR] results in an OSR of BAUD[OSR] + 1, for example, BAUD[OSR] = 0_0101b results in a final division by 6.</p> <p>0_0000b - Results in an OSR of 16</p> <p>0_0001b - Reserved</p> <p>0_0010b - Reserved</p> <p>0_0011b - Results in an OSR of 4 (requires BAUD[BOTHEDGE] to be 1)</p> <p>0_0100b - Results in an OSR of 5 (requires BAUD[BOTHEDGE] to be 1)</p> <p>0_0101b - Results in an OSR of 6 (requires BAUD[BOTHEDGE] to be 1)</p> <p>0_0110b - Results in an OSR of 7 (requires BAUD[BOTHEDGE] to be 1)</p> <p>0_0111b - Results in an OSR of 8</p> <p>0_1000b - Results in an OSR of 9</p> <p>0_1001b - Results in an OSR of 10</p> <p>0_1010b - Results in an OSR of 11</p> <p>0_1011b - Results in an OSR of 12</p> <p>0_1100b - Results in an OSR of 13</p> <p>0_1101b - Results in an OSR of 14</p> <p>0_1110b - Results in an OSR of 15</p> <p>0_1111b - Results in an OSR of 16</p> <p>1_0000b - Results in an OSR of 17</p> <p>1_0001b - Results in an OSR of 18</p> <p>1_0010b - Results in an OSR of 19</p> <p>1_0011b - Results in an OSR of 20</p> <p>1_0100b - Results in an OSR of 21</p> <p>1_0101b - Results in an OSR of 22</p> <p>1_0110b - Results in an OSR of 23</p> <p>1_0111b - Results in an OSR of 24</p> <p>1_1000b - Results in an OSR of 25</p> <p>1_1001b - Results in an OSR of 26</p> <p>1_1010b - Results in an OSR of 27</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | 1_1011b - Results in an OSR of 28<br>1_1100b - Results in an OSR of 29<br>1_1101b - Results in an OSR of 30<br>1_1110b - Results in an OSR of 31<br>1_1111b - Results in an OSR of 32                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 23<br>TDMAE     | Transmitter DMA Enable<br>Enables <a href="#">STAT[TDRE]</a> to generate a DMA request.<br>0b - Disable<br>1b - Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 22<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 21<br>RDMAE     | Receiver Full DMA Enable<br>Enables <a href="#">STAT[RDRF]</a> to generate a DMA request.<br>0b - Disable<br>1b - Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 20<br>RIDMAE    | Receiver Idle DMA Enable<br>Enables <a href="#">STAT[IDLE]</a> to generate a DMA request.<br>If this field is 1, reading <a href="#">Data (DATA)</a> when either <a href="#">DATA[RXEMPT]</a> or <a href="#">DATA[IDLINE]</a> is 1 generates an end-of-packet response until the completion of the DMA minor loop. During an end-of-packet response, reading <a href="#">Data (DATA)</a> returns 0000_33FFh and does not pull data from the receive FIFO. <a href="#">STAT[IDLE]</a> becomes 0 on completion of the minor loop, provided an end-of-packet response is generated and either the receive FIFO is empty or the receiver is active.<br>0b - Disable<br>1b - Enable |
| 19-18<br>MATCFG | Match Configuration<br>Configures the match addressing mode used.<br>You must change the value of this field only when both the transmitter and receiver are disabled.<br>00b - Address match wake-up<br>01b - Idle match wake-up<br>10b - Match on and match off<br>11b - Enables RWU on data match and match on or off for the transmitter CTS input                                                                                                                                                                                                                                                                                                                         |
| 17<br>BOTHEDGE  | Both Edge Sampling                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | <p>Enables sampling of the received data on both edges of the baud rate clock, effectively doubling the number of times the receiver samples the input data for a given OSR.</p> <p>This field must be 1 for OSRs between x4 and x7 and is optional for higher OSRs. You must change the value of this field only when the receiver is disabled.</p> <p>If this field is 0, the receiver samples input data using the rising edge of the baud rate clock. If this field is 1, the receiver samples input data using the rising and falling edges of the baud rate clock.</p> <p>0b - Rising edge<br/>1b - Both rising and falling edges</p> |
| 16<br>RESYNCDIS | <p>Resynchronization Disable</p> <p>Disables resynchronization of the received data word when a data one followed by data zero transition is detected.</p> <p>You must change the value of this field only when the receiver is disabled.</p> <p>0b - Enable<br/>1b - Disable</p>                                                                                                                                                                                                                                                                                                                                                           |
| 15<br>LBKDIS    | <p>LIN Break Detect Interrupt Enable</p> <p>Enables <a href="#">STAT[LBKDIS]</a> to generate hardware interrupt requests.</p> <p>If this field is 0, hardware interrupts from <a href="#">STAT[LBKDIS]</a> (uses polling) are disabled. If this field is 1, hardware interrupts are requested when <a href="#">STAT[LBKDIS]</a> is 1.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                               |
| 14<br>RXEDGIE   | <p>RX Input Active Edge Interrupt Enable</p> <p>Enables <a href="#">STAT[RXEDGIE]</a> to generate interrupt requests. If this field is 0, hardware interrupts from <a href="#">STAT[RXEDGIE]</a> are disabled. If this field is 1, hardware interrupts are requested when <a href="#">STAT[RXEDGIE]</a> is 1.</p> <p>Changing the value of <a href="#">CTRL[LOOPS]</a> or <a href="#">CTRL[RSRC]</a> when this field (RXEDGIE) is 1 can cause <a href="#">STAT[RXEDGIE]</a> to become 1.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                            |
| 13<br>SBNS      | <p>Stop Bit Number Select</p> <p>Determines whether data characters include one or two stop bits.</p> <p>You must change the value of this field only when both the transmitter and receiver are disabled.</p> <p>0b - One stop bit<br/>1b - Two stop bits</p>                                                                                                                                                                                                                                                                                                                                                                              |
| 12-0            | Baud Rate Modulo Divisor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SBR   | <p>Sets the modulo divide rate for the baud rate generator.</p> <ul style="list-style-type: none"> <li>If SBR is 0, baud rate generator is disabled.</li> <li>If SBR is 1–8191, baud rate = baud clock ÷ ((OSR + 1) × SBR). You must update the 13-bit baud rate setting [SBR12:SBR0] only when both the transmitter and receiver are disabled (both <a href="#">CTRL[RE]</a> and <a href="#">CTRL[TE]</a> are 0).</li> </ul> |

### 37.6.1.7 Status (STAT)

#### Offset

| Register | Offset |
|----------|--------|
| STAT     | 14h    |

#### Function

Provides the module status.

#### Diagram

| Bits  | 31         | 30          | 29 | 28   | 27    | 26        | 25    | 24        | 23  | 22   | 21 | 20   | 19   | 18  | 17  | 16    |     |
|-------|------------|-------------|----|------|-------|-----------|-------|-----------|-----|------|----|------|------|-----|-----|-------|-----|
| R     | LBKDI<br>F | RXED<br>GIF |    | MSBF | RXINV | RWUI<br>D | BRK13 | LBKD<br>E | RAF | TDRE | TC | RDRF | IDLE | OR  | NF  | FE    | PF  |
| W     | W1C        | W1C         |    |      |       |           |       |           |     |      |    |      | W1C  | W1C | W1C | W1C   | W1C |
| Reset | 0          | 0           | 0  | 0    | 0     | 0         | 0     | 0         | 1   | 1    | 0  | 0    | 0    | 0   | 0   | 0     |     |
| Bits  | 15         | 14          | 13 | 12   | 11    | 10        | 9     | 8         | 7   | 6    | 5  | 4    | 3    | 2   | 1   | 0     |     |
| R     | MA1F       | MA2F        |    | 0    |       | 0         |       |           |     |      |    | 0    |      | AME |     | LBKFE |     |
| W     | W1C        | W1C         |    |      |       |           |       |           |     |      |    |      | 0    | 0   | 0   | 0     |     |
| Reset | 0          | 0           | 0  | 0    | 0     | 0         | 0     | 0         | 0   | 0    | 0  | 0    | 0    | 0   | 0   | 0     |     |

#### Fields

| Field        | Function                                                                                                                                                                                                                                                                                                                         |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>LBKDIF | <p>LIN Break Detect Interrupt Flag</p> <p>Indicates whether a LIN break character is detected.</p> <p>This field becomes 1 when the LIN break detect circuitry is enabled and a LIN break character is detected.</p> <p><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | <p>0b - Not detected<br/>1b - Detected</p> <p>When writing<br/>0b - No effect<br/>1b - Clear the flag</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 30<br>RXEDGIF | <p>RXD Pin Active Edge Interrupt Flag<br/>Indicates whether an active edge on the receive pin has occurred.</p> <p>This field becomes 1 whenever the receiver is enabled and an active edge (falling if <a href="#">STAT[RXINV]</a> is 0; rising if <a href="#">STAT[RXINV]</a> is 1) on the RXD pin occurs.</p> <p style="text-align: center;"><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading<br/>0b - Not occurred<br/>1b - Occurred</p> <p>When writing<br/>0b - No effect<br/>1b - Clear the flag</p>                                                                                                                                                                                                                                                                                                                                       |
| 29<br>MSBF    | <p>MSB First<br/>Specifies the first bit that is transmitted after the start bit.</p> <p>If this field is 0, LSB (bit 0) is the first bit transmitted after the start bit (which means, the first bit received after the start bit is identified as bit 0).</p> <p>If this field is 1, MSB (identified as bit 9, bit 8, bit 7, or bit 6) is the first bit that is transmitted, after the start bit, depending on the settings of <a href="#">CTRL[M]</a>, <a href="#">CTRL[PE]</a>, and <a href="#">BAUD[M10]</a>.</p> <p>Writing 1 to this field reverses the order of the bits that are transmitted and received on the wire. This field does not affect the polarity of the bits, the location of the parity bit, or the location of the start or stop bits. You must change the value of this field only when both the transmitter and receiver are disabled.</p> <p>0b - LSB<br/>1b - MSB</p> |
| 28<br>RXINV   | <p>Receive Data Inversion<br/>Specifies whether receive data is inverted.</p> <p>Writing 1 to this field reverses the polarity of the received data input. You must change the value of this field only when the receiver is disabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | <p style="text-align: center;"><b>NOTE</b></p> <p>Writing 1 to this field inverts the RXD input for all cases: data bits, start and stop bits, break, and idle.</p> <p>0b - Inverted<br/>1b - Not inverted</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 27<br>RWUID | <p>Receive Wake Up Idle Detect</p> <p>Controls, for <a href="#">CTRL[RWU]</a> on idle character detection, whether the idle character that wakes up the receiver writes 1 to <a href="#">STAT[IDLE]</a>.</p> <p>For address match wake-up, this field controls whether <a href="#">STAT[IDLE]</a> = 1 when the address does not match. You must change the value of this field only when the receiver is disabled.</p> <p>If this field is 0, during the Receive Standby state (<a href="#">CTRL[RWU]</a> = 1), <a href="#">STAT[IDLE]</a> does not become 1 upon detection of an idle character. During address match wake-up, <a href="#">STAT[IDLE]</a> does not become 1 when an address does not match.</p> <p>If this field is 1, during the Receive Standby state (<a href="#">CTRL[RWU]</a> = 1), <a href="#">STAT[IDLE]</a> becomes 1 upon detection of an idle character. During address match wake-up, <a href="#">STAT[IDLE]</a> becomes 1 when an address does not match.</p> <p>0b - <a href="#">STAT[IDLE]</a> does not become 1<br/>1b - <a href="#">STAT[IDLE]</a> becomes 1</p> |
| 26<br>BRK13 | <p>Break Character Generation Length</p> <p>Selects the longer transmitted break character length.</p> <p>The state of this field does not affect the detection of a framing error. You must change the value of this field only when the transmitter is disabled. You can send a break character by writing 1 to <a href="#">CTRL[SBK]</a>, or by writing the transmit FIFO when <a href="#">DATA[FRETSC]</a> is 1 and <a href="#">DATA[R9T9]</a> is 0.</p> <p>0b - 9 to 13 bit times<br/>1b - 12 to 15 bit times</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 25<br>LBKDE | <p>LIN Break Detection Enable</p> <p>Enables LIN break detection.</p> <p>If this field is 0, LIN break detect is disabled, and only a normal break character can be detected.</p> <p>If this field is 1, LIN break detect is enabled and the LIN break character is detected at a length of 11 bit times (if <a href="#">CTRL[M]</a> is 0), 12 bit times (if <a href="#">CTRL[M]</a> is 1), or 13 bit times (if <a href="#">BAUD[M10]</a> is 1).</p> <p>This field selects a longer break character detection length. When the field is 1, receive data is not stored in the receive FIFO.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field enables the LIN break detect circuit and disables writing receive data to FIFO. Therefore, it ignores all characters except a LIN break.</p>                                                                                                                                                                                                                                                                                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | 0b - Disable<br>1b - Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 24<br>RAF  | Receiver Active Flag<br>Indicates whether the LPUART receiver is idle or active.<br>This field becomes 1 when the receiver detects the beginning of a valid start bit, and the field becomes 0 automatically when the receiver detects an idle line.<br>0b - Idle, waiting for a start bit<br>1b - Receiver active (RXD pin input not idle)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 23<br>TDRE | Transmit Data Register Empty Flag<br>Indicates whether the transmit FIFO level is greater than, equal to, or less than the watermark.<br>After the transmit FIFO is enabled, this field becomes 1 when the number of datawords in the transmit FIFO is equal to, or less than the number that <a href="#">WATER[TXWATER]</a> indicates. To make the value of this field 0, write to it until the number of words in the transmit FIFO is greater than the number that <a href="#">WATER[TXWATER]</a> indicates. After the transmit FIFO is disabled, this field becomes 1 to indicate that the FIFO level is less than the watermark. To make the value of this field 0 again, write to <a href="#">Data (DATA)</a> .<br>This register is not affected by a character that is in the process of being transmitted; it is updated at the start of each transmitted character.<br>0b - Greater than watermark<br>1b - Equal to or less than watermark |
| 22<br>TC   | Transmission Complete Flag<br>Indicates whether the transmitter is active.<br>This field becomes 0 when a transmission is in progress or a preamble or break character is loaded; in other words, when the transmitter is active (sending data, a preamble, or a break). The field becomes 1 when the transmit buffer is empty and no data, preamble, or break character is being transmitted; in other words, when the transmission activity is complete. When this happens, the transmit data output signal becomes idle (logic 1). This field becomes 0 after you write to <a href="#">Data (DATA)</a> to transmit new data, queuing a preamble by first writing 0 and then writing 1 to <a href="#">CTRL[TE]</a> , queuing a break character by writing 1 to <a href="#">CTRL[SBK]</a> .<br>0b - Transmitter active<br>1b - Transmitter idle                                                                                                    |
| 21<br>RDRF | Receive Data Register Full Flag<br>Indicates whether the receive FIFO level is less than, equal to, or greater than the watermark.<br>This field becomes 1 when the number of datawords in the receive buffer is greater than the number that <a href="#">WATER[RXWATER]</a> indicates and the receive FIFO is enabled. To write 0 to this field, read <a href="#">Data (DATA)</a> until the number of datawords in the receive FIFO is equal to, or less than the number that <a href="#">WATER[RXWATER]</a> indicates. When the receive FIFO is disabled, this field (RDRF) becomes 1 if the receive buffer ( <a href="#">Data (DATA)</a> ) is full. To make this field 0, read <a href="#">Data (DATA)</a> .                                                                                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | <p>A character that is in the process of being received does not cause a change in this field until the entire character is received. Even if this field is 1, the character continues to be received until an overrun condition occurs after the entire character is received.</p> <p>0b - Equal to or less than watermark<br/>1b - Greater than watermark</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 20<br>IDLE | <p>Idle Line Flag</p> <p>Indicates whether an idle line is detected.</p> <p>This field becomes 1 when the LPUART receive line becomes idle for a full character time after a period of activity. When <a href="#">CTRL[ILT]</a> is 0, the receiver starts counting idle bit times after the start bit. If the receive character is all 1s, these bit times and the stop bit time count towards the full character time of logic high, 10 to 13 bit times, needed for the receiver to detect an idle line. After <a href="#">CTRL[ILT]</a> becomes 1, the receiver does not start counting idle bit times until after the stop bits. The stop bits and any logic high bit times at the end of the previous character do not count towards the full character time of logic high needed for the receiver to detect an idle line.</p> <p>For this field to become 0, write 1 to it. After the field becomes 0, you cannot write 1 to it again until after a new character is stored in the receive buffer or a LIN break character writes 1 to <a href="#">STAT[LBKDIF]</a>. This field becomes 1 only once, even if the receive line remains idle for an extended period.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <p>0b - Idle line detected<br/>1b - Idle line not detected</p> <p>When writing</p> <p>0b - No effect<br/>1b - Clear the flag</p> |
| 19<br>OR   | <p>Receiver Overrun Flag</p> <p>Indicates whether there is receive overrun.</p> <p>This field becomes 1 when you cannot prevent <a href="#">STAT[RDRF]</a> from overflowing with data. The field becomes 1 immediately after the stop bit is completely received for the dataword that overflows the buffer and all the other error fields (<a href="#">STAT[FE]</a>, <a href="#">STAT[NF]</a>, and <a href="#">STAT[PF]</a>) are prevented from becoming 1. The data in the shift register is lost, but the data already in the LPUART data registers is not affected. If <a href="#">STAT[LBKDE]</a> is enabled and a LIN break is detected, this field becomes 1 if <a href="#">STAT[LBKDIF]</a> is not 0 before the next data character is received.</p> <p>When this field is 1, no additional data is stored in the receive FIFO even if sufficient room exists.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p>                                                                                                                                                                                                                                                                                                                                                                                                                                   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | <p>0b - No overrun<br/>1b - Receive overrun (new LPUART data is lost)</p> <p>When writing<br/>0b - No effect<br/>1b - Clear the flag</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 18<br>NF | <p>Noise Flag<br/>Indicates whether noise is detected in the received character of <a href="#">Data (DATA)</a>.<br/>The advanced sampling technique used in the receiver takes three samples in each of the received bits. If some of these samples disagree with the rest of the samples within any bit time in the frame, then noise is detected for that character. This field becomes 1 whenever the next character to be read from <a href="#">Data (DATA)</a> is received with noise detected within the character.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading<br/>0b - No noise detected<br/>1b - Noise detected</p> <p>When writing<br/>0b - No effect<br/>1b - Clear the flag</p> |
| 17<br>FE | <p>Framing Error Flag<br/>Indicates whether a framing error is detected.<br/>This field becomes 1 whenever the next character to be read from <a href="#">Data (DATA)</a> is received with logic 0 detected where a stop bit was expected.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading<br/>0b - No framing error detected (this does not guarantee that the framing is correct)<br/>1b - Framing error detected</p> <p>When writing<br/>0b - No effect<br/>1b - Clear the flag</p>                                                                                                                                                                                                          |
| 16<br>PF | <p>Parity Error Flag<br/>Indicates whether a parity error is detected.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | <p>This field becomes 1 whenever the next character to be read from <b>Data (DATA)</b> is received when parity is enabled (<b>CTRL[PE]</b> is 1) and the parity bit in the received character does not agree with the expected parity value.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - No parity error detected</li> <li>1b - Parity error detected</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul> |
| 15<br>MA1F | <p>Match 1 Flag</p> <p>Indicates whether the received data is equal to <b>MATCH[MA1]</b>.</p> <p>This field becomes 1 whenever the next character to be read from <b>Data (DATA)</b> matches the value of <b>MATCH[MA1]</b>.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - Not equal to MA1</li> <li>1b - Equal to MA1</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul>                                  |
| 14<br>MA2F | <p>Match 2 Flag</p> <p>Indicates whether the received data is equal to <b>MATCH[MA2]</b>.</p> <p>This field becomes 1 whenever the next character to be read from <b>Data (DATA)</b> matches the value of <b>MATCH[MA2]</b>.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - Not equal to MA2</li> <li>1b - Equal to MA2</li> </ul> <p>When writing</p>                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | 0b - No effect<br>1b - Clear the flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 13-10<br>— | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 9-8<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 7-2<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1<br>AME   | <p>Address Mark Enable</p> <p>Configures the location of the address mark when configured for MSB first transfers.</p> <p>This field has no effect when configured for LSB first and you must change the value of this field only when both the transmitter and receiver are disabled. If this field is 0, address mark in character is MSB. If this field is 1, the address mark is stored in <a href="#">Data (DATA)</a> at MSB (or MSB-1 when the parity bit is enabled). In other words, the address mark in character is the last bit before the stop bit (or parity bit when enabled).</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                                                                                                                                  |
| 0<br>LBKFE | <p>LIN Break Flag Enable</p> <p>Enables the LIN break flag to assert whenever a LIN break character is detected.</p> <p>Unlike <a href="#">STAT[LBKDE]</a>, this does not impact data being stored in the receive data buffer, but does cause <a href="#">STAT[LBKDIF]</a> to become 1 whenever a LIN break is detected.</p> <p>Because a LIN break is longer than a normal character, the LIN break triggers a write to <a href="#">STAT[RDRF]</a> with the data fields as 0 and <a href="#">STAT[FE]</a> as 1. The character following the LIN break has <a href="#">DATA[LINBRK]</a> as 1 to indicate that the previous character was a LIN break.</p> <p>You must change the value of this field only when both the transmitter and receiver are disabled.</p> <p>If this field is 1, the LIN break character is detected at a length of 11-bit times (if <a href="#">CTRL[M]</a> is 0), 12 (if <a href="#">CTRL[M]</a> is 1), or 13 (if <a href="#">BAUD[M10]</a> is 1).</p> <p>0b - Disable<br/>1b - Enable</p> |

### 37.6.1.8 Control (CTRL)

#### Offset

| Register | Offset |
|----------|--------|
| CTRL     | 18h    |

**Function**

Controls various optional features of the LPUART system.

You must write to the fields of this register only when both the transmitter and receiver are disabled.

**Diagram**

| Bits  | 31    | 30    | 29    | 28    | 27   | 26      | 25   | 24   | 23     | 22      | 21   | 20   | 19   | 18  | 17  | 16  |
|-------|-------|-------|-------|-------|------|---------|------|------|--------|---------|------|------|------|-----|-----|-----|
| R     | R8T9  | R9T8  | TXDIR | TXINV | ORIE | NEIE    | FEIE | PEIE | TIE    | TCIE    | RIE  | ILIE | TE   | RE  | RWU | SBK |
| W     |       |       |       |       |      |         |      |      |        |         |      |      |      |     |     |     |
| Reset | 0     | 0     | 0     | 0     | 0    | 0       | 0    | 0    | 0      | 0       | 0    | 0    | 0    | 0   | 0   | 0   |
| Bits  | 15    | 14    | 13    | 12    | 11   | 10      | 9    | 8    | 7      | 6       | 5    | 4    | 3    | 2   | 1   | 0   |
| R     | MA1IE | MA2IE | 0     | 0     | M7   | IDLECFG |      |      | LOOP S | DOZE EN | RSRC | M    | WAKE | ILT | PE  | PT  |
| W     |       |       |       |       |      |         |      |      |        |         |      |      |      |     |     |     |
| Reset | 0     | 0     | 0     | 0     | 0    | 0       | 0    | 0    | 0      | 0       | 0    | 0    | 0    | 0   | 0   | 0   |

**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>R8T9 | <p>Receive Bit 8 Transmit Bit 9</p> <p>Contains R8 and T9 that correspond to different functions.</p> <p>R8 is the ninth data bit received after you configure LPUART for 9-bit or 10-bit data formats. When reading 9-bit or 10-bit data, read R8 before reading <a href="#">Data (DATA)</a>.</p> <p>T9 is the tenth data bit transmitted after you configure LPUART for 10-bit data formats. When writing 10-bit data, write T9 before writing to <a href="#">Data (DATA)</a>. If T9 does not need to change from its previous value, such as when it is used to generate address mark or parity, then you need not write to it each time you write to <a href="#">Data (DATA)</a>.</p> <p><b>NOTE</b></p> <p>R8 is a read-only bit and T9 is a write-only bit; the value read is different from the value written.</p>     |
| 30<br>R9T8 | <p>Receive Bit 9 Transmit Bit 8</p> <p>Contains R9 and T8 that correspond to different functions.</p> <p>R9 is the tenth data bit received after you configure LPUART for 10-bit data formats. When reading 10-bit data, read R9 before reading <a href="#">Data (DATA)</a>.</p> <p>T8 is the ninth data bit transmitted after you configure LPUART for 9-bit or 10-bit data formats. When writing 9-bit or 10-bit data, write T8 before writing to <a href="#">Data (DATA)</a>. If T8 does not need to change from its previous value, such as when it is used to generate address mark or parity, then you need not write to it each time you write to <a href="#">Data (DATA)</a>.</p> <p><b>NOTE</b></p> <p>R9 is a read-only field and T8 is a write-only field; the value read is different from the value written.</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29<br>TXDIR | <p>TXD Pin Direction in Single-Wire Mode</p> <p>Determines the direction of data at the TXD pin, in Single-Wire mode, when LPUART is configured for a single-wire half-duplex operation (<a href="#">CTRL[LOOPS]</a> and <a href="#">CTRL[RSRC]</a> are 1). When writing 0 to this field, the transmitter finishes transmitting the current character (if any) before the receiver starts receiving data from the TXD pin.</p> <p>0b - Input<br/>1b - Output</p> |
| 28<br>TXINV | <p>Transmit Data Inversion</p> <p>Specifies whether transmit data is inverted.</p> <p>Writing 1 to this field reverses the polarity of the transmitted data output. This action inverts the TXD output for all cases: data bits, start and stop bits, break, and idle.</p> <p>0b - Not inverted<br/>1b - Inverted</p>                                                                                                                                            |
| 27<br>ORIE  | <p>Overrun Interrupt Enable</p> <p>Enables <a href="#">STAT[OR]</a> to generate hardware interrupt requests. When this field is 1, a hardware interrupt is requested. Use polling when OR interrupts are disabled.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                       |
| 26<br>NEIE  | <p>Noise Error Interrupt Enable</p> <p>Enables <a href="#">STAT[NF]</a> to generate hardware interrupt requests. When this field is 1, a hardware interrupt is requested. Use polling when NF interrupts are disabled.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                   |
| 25<br>FEIE  | <p>Framing Error Interrupt Enable</p> <p>Enables <a href="#">STAT[FE]</a> to generate hardware interrupt requests. When this field is 1, a hardware interrupt is requested. Use polling when FE interrupts are disabled.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                 |
| 24<br>PEIE  | <p>Parity Error Interrupt Enable</p> <p>Enables <a href="#">STAT[PF]</a> to generate hardware interrupt requests. When this field is 1, a hardware interrupt is requested. Use polling when PF interrupts are disabled.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                  |
| 23          | Transmit Interrupt Enable                                                                                                                                                                                                                                                                                                                                                                                                                                        |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TIE        | Enables <a href="#">STAT[TDRE]</a> to generate interrupt requests if STAT[TDRE] is 1.<br>0b - Disable<br>1b - Enable                                                                                                                                                                                                                                                                                                                                                                         |
| 22<br>TCIE | Transmission Complete Interrupt Enable<br>Enables <a href="#">STAT[TC]</a> to generate interrupt requests if STAT[TC] is 1.<br>0b - Disable<br>1b - Enable                                                                                                                                                                                                                                                                                                                                   |
| 21<br>RIE  | Receiver Interrupt Enable<br>Enables <a href="#">STAT[RDRF]</a> to generate hardware interrupt requests if STAT[RDRF] is 1.<br>0b - Disable<br>1b - Enable                                                                                                                                                                                                                                                                                                                                   |
| 20<br>ILIE | Idle Line Interrupt Enable<br>Enables hardware interrupts.<br>This field enables <a href="#">STAT[IDLE]</a> to generate interrupt requests.<br>If this field is 0, hardware interrupts from STAT[IDLE] are disabled and polling is used, and if this field is 1, hardware interrupts are enabled when STAT[IDLE] is 1.<br>0b - Disable<br>1b - Enable                                                                                                                                        |
| 19<br>TE   | Transmitter Enable<br>Enables the LPUART transmitter.<br>Using this field, you can also queue an idle preamble by first writing 0 and then writing 1 to this field. After this field becomes 0, the field reads 1 until the transmitter has completed the current character and the TXD pin is tristated.<br>You can also queue a single idle character by writing to the transmit FIFO with <a href="#">DATA[FRETSC]</a> and <a href="#">DATA[R9T9]</a> = 1.<br>0b - Disable<br>1b - Enable |
| 18<br>RE   | Receiver Enable<br>Enables the LPUART receiver.<br>After you write 0 to this field, this field remains 1 until the receiver finishes receiving the current character (if any).<br>0b - Disable<br>1b - Enable                                                                                                                                                                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17<br>RWU   | <p>Receiver Wake-Up Control</p> <p>Specifies whether the LPUART receiver in standby is waiting for a wake-up condition.</p> <p>You can write 1 to this field to place the LPUART receiver in a Standby state. The field becomes 0 automatically when an RWU event occurs, that is, in case of an idle event when <a href="#">CTRL[WAKE]</a> is 0 or an address match when <a href="#">CTRL[WAKE]</a> is 1 and <a href="#">STAT[RWUID]</a> is 0.</p> <p><b>NOTE</b></p> <p>You must write 1 to this field only when <a href="#">CTRL[WAKE]</a> is 0 (wake-up on idle), if the channel is currently not idle. You can determine this by the value of <a href="#">STAT[RAF]</a>. If the field is 1 to wake up an idle event and the channel is already idle, LPUART, possibly, discards the data. This is because the data must be received or a LIN break is detected after an Idle condition is detected before the IDLE flag is allowed to be reasserted.</p> <p>0b - Normal receiver operation</p> <p>1b - LPUART receiver in standby, waiting for a wake-up condition</p>                                 |
| 16<br>SBK   | <p>Send Break</p> <p>Specifies whether queue break character(s) are to be sent.</p> <p>Writing 1 and then 0 to this field queues a break character in the transmit data stream. Additional break characters of 9 to 13 bits, or 12 to 15 bits if <a href="#">STAT[BRK13]</a> is 1, and bit times of logic 0 are queued as long as this field is 1. Depending on the timing when this field is 1 and 0, relative to the character currently being transmitted, a second break character may be queued before you write 0 to this field. If the time taken to write 0 to this field is too long, for example, if the field does not become 0 by the end of the first break character, a second break character is sent. This is compared to queuing a break character through the transmit FIFO that guarantees only one break character is sent.</p> <p>You can also queue a single break character by writing to the transmit FIFO when <a href="#">DATA[FRETSC]</a> is 1 and <a href="#">DATA[R9T9]</a> is 0.</p> <p>0b - Normal transmitter operation</p> <p>1b - Queue break character(s) to be sent</p> |
| 15<br>MA1IE | <p>Match 1 (MA1F) Interrupt Enable</p> <p>Enables the MA1F interrupt.</p> <p>0b - Disable</p> <p>1b - Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 14<br>MA2IE | <p>Match 2 (MA2F) Interrupt Enable</p> <p>Enables the MA2F interrupt.</p> <p>0b - Disable</p> <p>1b - Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 13<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 11<br>M7        | 7-Bit Mode Select<br><br>Specifies the data characters that the receiver and transmitter use.<br><br>You must change the value of this field only after both the transmitter and receiver are disabled.<br><br>0b - 8-bit to 10-bit<br>1b - 7-bit                                                                                                                                                                                                                                                                       |
| 10-8<br>IDLECFG | Idle Configuration<br><br>Configures the number of idle characters that must be received before you write 1 to <a href="#">STAT[IDLE]</a> .<br><br>000b - 1<br>001b - 2<br>010b - 4<br>011b - 8<br>100b - 16<br>101b - 32<br>110b - 64<br>111b - 128                                                                                                                                                                                                                                                                    |
| 7<br>LOOPS      | Loop Mode Select<br><br>Selects Loop mode.<br><br>After this field becomes 1, the RXD pin is disconnected from LPUART and the transmitter output is internally connected to the receiver input. The transmitter and receiver must be enabled to use the loop function.<br>In Loop mode or Single-Wire mode, the transmitter outputs are internally connected to the receiver input (see <a href="#">CTRL[RSRC]</a> ).<br><br>0b - Normal operation: RXD and TXD use separate pins<br>1b - Loop mode or Single-Wire mode |
| 6<br>DOZEEN     | Doze Mode<br><br>Enables LPUART in Doze mode.<br><br>If this field is 1, LPUART remains active when not in Doze mode.<br><br>0b - Enable<br>1b - Disable                                                                                                                                                                                                                                                                                                                                                                |
| 5<br>RSRC       | Receiver Source Select<br><br>Determines the source of the receiver shift register input if <a href="#">CTRL[LOOPS]</a> is 1.<br><br>This field has no effect unless <a href="#">CTRL[LOOPS]</a> is 1.                                                                                                                                                                                                                                                                                                                  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | <p>If this field is 0, internal Loopback mode is selected. LPUART does not use the RXD pin. Additionally, the CTS_B pin is not used and internally driven by the RTS_B output.</p> <p>If this field is 1, single-wire LPUART mode is selected where the TXD pin is connected to the transmitter output and receiver input.</p> <ul style="list-style-type: none"> <li>0b - Internal Loopback mode</li> <li>1b - Single-wire mode</li> </ul>                                                                                                                                                                                                                                                                                                   |
| 4<br>M    | <p>9-Bit Or 8-Bit Mode Select</p> <p>Specifies the data characters that the receiver and transmitter use.</p> <ul style="list-style-type: none"> <li>0b - 8-bit</li> <li>1b - 9-bit</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3<br>WAKE | <p>Receiver Wake-Up Method Select</p> <p>Determines which condition wakes up LPUART when <b>CTRL[RWU]</b> = 1 and <b>BAUD[MATCFG]</b> = 0 (this field must be 1 when <b>BAUD[MATCFG]</b> = 11):</p> <ul style="list-style-type: none"> <li>• Address mark in the bit preceding the stop bit (or bit preceding the parity bit when parity is enabled) of the received data character</li> <li>• An idle condition on the receive pin input signal</li> </ul> <p>If this field is 0, <b>CTRL[RWU]</b> is configured for idle line wake-up, and if this field is 1, <b>CTRL[RWU]</b> is configured with address mark wake-up.</p> <ul style="list-style-type: none"> <li>0b - Idle</li> <li>1b - Mark</li> </ul>                                 |
| 2<br>ILT  | <p>Idle Line Type Select</p> <p>Determines when the receiver starts counting logic 1s as idle character bits.</p> <p>The count begins either after a valid start bit or the stop bit. If the count begins after the start bit, a string of logic 1s preceding the stop bit can cause false recognition of an idle character. Beginning the count after the stop bit avoids false idle character recognition, but requires properly synchronized transmissions.</p> <p><b>NOTE</b></p> <p>In case you write 1 to this field, a logic 0 is automatically shifted after a received stop bit, therefore resetting the idle count.</p> <ul style="list-style-type: none"> <li>0b - After the start bit</li> <li>1b - After the stop bit</li> </ul> |
| 1<br>PE   | <p>Parity Enable</p> <p>Enables hardware parity generation and checking.</p> <p>If parity is enabled, the bit immediately before the stop bit is treated as the parity bit.</p> <ul style="list-style-type: none"> <li>0b - Disable</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field   | Function                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | 1b - Enable                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0<br>PT | Parity Type<br>Selects the type of parity, even or odd, if parity is enabled ( <a href="#">CTRL[PE]</a> = 1): <ul style="list-style-type: none"> <li>Odd parity means that the total number of logic 1 bits in the data character, including the parity bit, is odd.</li> <li>Even parity means that the total number of 1s in the data character, including the parity bit, is even.</li> </ul> 0b - Even parity<br>1b - Odd parity |

### 37.6.1.9 Data (DATA)

#### Offset

| Register | Offset |
|----------|--------|
| DATA     | 1Ch    |

#### Function

Supports 8-bit, 16-bit, or 32-bit writes, each type of write performing a separate function. An 8-bit write to DATA[7:0] pushes [CTRL\[R8T9\]](#), [CTRL\[R9T8\]](#), DATA[7:0]) the transmit FIFO with TSC clear. A 16-bit or 32-bit write pushes the data written into the FIFO and does not update the value of [CTRL\[R8T9\]](#) or [CTRL\[R9T8\]](#).

Reads and writes of this register are also involved in the automatic flag clearing mechanisms for some of the LPUART status fields.

#### NOTE

Reads return the contents of the read-only receive FIFO and writes go to the write-only transmit FIFO, making this register work as a set of two separate registers.

#### Diagram

| Bits  | 31    | 30       | 29      | 28      | 27      | 26      | 25   | 24   | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|-------|-------|----------|---------|---------|---------|---------|------|------|------|------|------|------|------|------|------|------|
| R     | 0     |          |         |         |         |         |      |      |      |      |      |      |      |      |      |      |
| W     |       |          |         |         |         |         |      |      |      |      |      |      |      |      |      |      |
| Reset | 0     | 0        | 0       | 0       | 0       | 0       | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |
| Bits  | 15    | 14       | 13      | 12      | 11      | 10      | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| R     | NOISY | PARIT YE | FRET SC | RXEM PT | IDLIN E | LINBR K | R9T9 | R8T8 | R7T7 | R6T6 | R5T5 | R4T4 | R3T3 | R2T2 | R1T1 | R0T0 |
| W     |       |          |         |         |         |         |      |      |      |      |      |      |      |      |      |      |
| Reset | 0     | 0        | 0       | 1       | 0       | 0       | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

## Fields

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 15<br>NOISY   | Noisy Data Received<br>Indicates whether the current received dataword contained in DATA[R9:R0] is received with noise.<br>0b - Received without noise<br>1b - Received with noise                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 14<br>PARITYE | Parity Error<br>Indicates whether the current received dataword contained in DATA[R9:R0] is received with a parity error.<br>0b - Received without a parity error<br>1b - Received with a parity error                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 13<br>FRETSC  | Frame Error Transmit Special Character<br>Specifies the way the dataword is received.<br>For reads, this field indicates that the current received dataword contained in DATA[R9:R0] is received with a frame error. For writes, the field indicates that a break or idle character is to be transmitted instead of the contents in DATA[T9:T0]. T9 indicates a break character when it is 0 and indicates an idle character when it is 1. The contents of DATA[T8:T0] must be 0.<br>0b - Received without a frame error on reads or transmits a normal character on writes<br>1b - Received with a frame error on reads or transmits an idle or break character on writes |
| 12<br>RXEMPT  | Receive Buffer Empty<br>Indicates whether the receive buffer contains valid data.<br>This field becomes 1 when there is no data in the receive buffer. The field does not consider data in the receive shift register.<br>0b - Valid data<br>1b - Invalid data and empty                                                                                                                                                                                                                                                                                                                                                                                                   |
| 11<br>IDLIN   | Idle Line<br>Indicates whether the receiver line was idle before receiving the character in DATA[9:0]. Unlike <a href="#">STAT[IDLE]</a> , you can write 1 to this field for the first character received when the receiver is first enabled.<br>0b - Not idle<br>1b - Idle                                                                                                                                                                                                                                                                                                                                                                                                |
| 10<br>LINBRK  | LIN Break<br>Indicates whether the receiver line detected a LIN break before receiving the character in DATA[9:0]. This field requires the value of <a href="#">STAT[LBKDIF]</a> to be 1. If this field is 0, the LIN break detect circuitry is disabled.                                                                                                                                                                                                                                                                                                                                                                                                                  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                             |
|-----------|------------------------------------------------------|
|           | 0b - Not detected<br>1b - Detected                   |
| 9<br>R9T9 | Read receive FIFO bit 9 or write transmit FIFO bit 9 |
| 8<br>R8T8 | Read receive FIFO bit 8 or write transmit FIFO bit 8 |
| 7<br>R7T7 | Read receive FIFO bit 7 or write transmit FIFO bit 7 |
| 6<br>R6T6 | Read receive FIFO bit 6 or write transmit FIFO bit 6 |
| 5<br>R5T5 | Read receive FIFO bit 5 or write transmit FIFO bit 5 |
| 4<br>R4T4 | Read receive FIFO bit 4 or write transmit FIFO bit 4 |
| 3<br>R3T3 | Read receive FIFO bit 3 or write transmit FIFO bit 3 |
| 2<br>R2T2 | Read receive FIFO bit 2 or write transmit FIFO bit 2 |
| 1<br>R1T1 | Read receive FIFO bit 1 or write transmit FIFO bit 1 |
| 0<br>R0T0 | Read receive FIFO bit 0 or write transmit FIFO bit 0 |

### 37.6.1.10 Match Address (MATCH)

#### Offset

| Register | Offset |
|----------|--------|
| MATCH    | 20h    |

#### Function

Provides addresses for address matching during the receiver operation.

**Diagram**

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

**Fields**

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-26<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 25-16<br>MA2 | Match Address 2<br><br>Is compared to input data addresses when the most significant bit is 1 and the associated <a href="#">Baud Rate (BAUD)</a> field is 1.<br><br>If a match occurs, the data that follows is transferred to <a href="#">Data (DATA)</a> . If a match fails, the data that follows is discarded. You must write to <a href="#">MATCH[MA1]</a> and <a href="#">MATCH[MA2]</a> only when the associated <a href="#">Baud Rate (BAUD)</a> field is 0.        |
| 15-10<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 9-0<br>MA1   | Match Address 1<br><br>Is compared to input data addresses when the most significant bit is 1 and the associated <a href="#">Baud Rate (BAUD)</a> field is 1.<br><br>If a match occurs, the data that follows is transferred to <a href="#">Data (DATA)</a> . If a match fails, the data that follows is discarded. You must write to <a href="#">MATCH[MA1]</a> and <a href="#">MATCH[MA2]</a> fields only when the associated <a href="#">Baud Rate (BAUD)</a> field is 0. |

**37.6.1.11 MODEM IrDA (MODIR)****Offset**

| Register | Offset |
|----------|--------|
| MODIR    | 24h    |

**Function**

Controls options for setting the MODEM configuration.

**Diagram**

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23       | 22 | 21 | 20 | 19           | 18         | 17         | 16           |            |            |
|-------|----|----|----|----|----|----|----|----|----------|----|----|----|--------------|------------|------------|--------------|------------|------------|
| R     |    |    |    |    |    |    |    |    | 0        |    |    |    |              | IREN       |            | TNP          |            |            |
| W     |    |    |    |    |    |    |    |    |          |    |    |    |              |            |            |              |            |            |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0  | 0  | 0  | 0            | 0          | 0          | 0            |            |            |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7        | 6  | 5  | 4  | 3            | 2          | 1          | 0            |            |            |
| R     |    |    |    |    | 0  |    |    |    | RTSWATER |    | 0  |    | TXCT<br>SSRC | TXCT<br>SC | RXRT<br>SE | TXRT<br>SPOL | TXRT<br>SE | TXCT<br>SE |
| W     |    |    |    |    |    |    |    |    |          |    | 0  | 0  | 0            | 0          | 0          | 0            |            |            |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0  | 0  | 0  | 0            | 0          | 0          | 0            |            |            |

**Fields**

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-19    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| —        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 18       | IR Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| IREN     | Enables IR modulation and demodulation.<br><br>You must change the value of this field only when both the transmitter and receiver are disabled.<br><br>0b - Disable<br>1b - Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 17-16    | Transmitter Narrow Pulse                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| TNP      | Specifies whether LPUART transmits a $1 \div \text{OSR}$ , $2 \div \text{OSR}$ , $3 \div \text{OSR}$ , or $4 \div \text{OSR}$ narrow pulse when the IR pulse is enabled.<br><br>You must change the value of this field only when both the transmitter and receiver are disabled.<br><br>The IR pulse width must be configured to less than half of the OSR. Common pulse widths are $3 \div 16$ , $1 \div 16$ , $1 \div 32$ , or $1 \div 4$ of the bit length. You can configure these by selecting the appropriate OSR and pulse width.<br><br>00b - $1 \div \text{OSR}$<br>01b - $2 \div \text{OSR}$<br>10b - $3 \div \text{OSR}$<br>11b - $4 \div \text{OSR}$ |
| 15-10    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| —        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 9-8      | Receive RTS Configuration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| RTSWATER | Configures the assertion and negation of the receiver's RTS_B output.<br><br>The receiver's RTS_B output negates when the number of empty words in the receive FIFO is greater or equal to the value of this field. If this field is 0, the RTS_B pin negates when the receive FIFO is full. For the                                                                                                                                                                                                                                                                                                                                                              |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | <p>purpose of receive RTS_B generation, the number of words in the receive FIFO updates when a start bit is detected. This supports additional latency between RTS_B negation and the external transmitter ceasing transmission. If both receive RTS_B and address or data matching is enabled, RTS_B could assert at the end of a character if there exists no match.</p> <p>You must change the value of this field only when the receiver is disabled.</p>                                                                                                                                                                                                                                                                                             |
| 7-6<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5<br>TXCTSSRC | <p>Transmit CTS Source</p> <p>Configures the source of the CTS input.</p> <p>0b - The CTS_B pin</p> <p>1b - An internal connection to the receiver address match result</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 4<br>TXCTSC   | <p>Transmit CTS Configuration</p> <p>Configures whether the CTS state or input is checked or sampled at the start of each character or only when the transmitter is idle.</p> <p>0b - Sampled at the start of each character</p> <p>1b - Sampled when the transmitter is idle</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3<br>RXRTSE   | <p>Receiver RTS Enable</p> <p>Allows the RTS output to control the CTS input of the transmitting device to prevent receiver overrun.</p> <p>You must change the value of this field only when the receiver is disabled.</p> <p>If this field is 0, the receiver has no effect on RTS.</p> <p>If this field is 1, RTS is deasserted if <a href="#">STAT[RDRF]</a> is 1 or a start bit is detected that causes <a href="#">STAT[RDRF]</a> to become 1. RTS is asserted if <a href="#">STAT[RDRF]</a> is 0 and has not detected a start bit that causes <a href="#">STAT[RDRF]</a> to become 1.</p> <p><b>NOTE</b></p> <p>Do not write 1 to both <a href="#">MODIR[RXRTSE]</a> and <a href="#">MODIR[TXRTSE]</a>.</p> <p>0b - Disable</p> <p>1b - Enable</p> |
| 2<br>TXRTSPOL | <p>Transmitter RTS Polarity</p> <p>Controls the polarity of the transmitter RTS.</p> <p>This field does not affect the polarity of the receiver RTS that remains negated in the active-low state unless <a href="#">MODIR[TXRTSE]</a> is 1. You must change the value of this field only when the transmitter is disabled.</p> <p>0b - Active low</p> <p>1b - Active high</p>                                                                                                                                                                                                                                                                                                                                                                             |
| 1             | Transmitter RTS Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TXRTSE      | <p>Controls the operation of RTS before and after a transmission.</p> <p>You must change the value of this field only when the transmitter is disabled. If this field is 0, the transmitter has no effect on RTS, and if this field is 1, a character is placed into an empty transmit shift register. RTS asserts 1-bit time before the start bit is transmitted and deasserts 1-bit time after all characters in the transmitter FIFO and shift register are completely sent, including the last stop bit.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                  |
| 0<br>TXCTSE | <p>Transmitter CTS Enable</p> <p>Enables the operation of the transmitter.</p> <p>You can write 1 to this field irrespective of the states of <a href="#">MODIR[TXRTSE]</a> and <a href="#">MODIR[RXRTSE]</a>. If this field is 1, the transmitter checks the state of the CTS signal each time it is ready to send a character. If CTS is asserted, the character is sent. If CTS is deasserted, the TXD signal remains in the mark state and transmission is delayed until CTS is asserted. Changes in CTS, when a character is being sent, do not affect its transmission.</p> <p>0b - Disable<br/>1b - Enable</p> |

### 37.6.1.12 FIFO (FIFO)

#### Offset

| Register | Offset |
|----------|--------|
| FIFO     | 28h    |

#### Function

Provides you the ability to turn on and turn off the FIFO functionality.

This register also provides you the size of the FIFO that has been implemented. You can read this register at any time and must write to it only when [CTRL\[RE\]](#) and [CTRL\[TE\]](#) are 0 and the FIFO is empty.

**Diagram**

| Bits  | 31      | 30      | 29 | 28 | 27     | 26 | 25 | 24    | 23         | 22     | 21 | 20 | 19         | 18 | 17   | 16   |
|-------|---------|---------|----|----|--------|----|----|-------|------------|--------|----|----|------------|----|------|------|
| R     |         |         |    |    | 0      |    |    |       | TXEMPT     | RXEMPT |    |    | 0          |    | TXOF | RXUF |
| W     |         |         |    |    |        |    |    |       |            |        |    |    |            |    | W1C  | W1C  |
| Reset | 0       | 0       | 0  | 0  | 0      | 0  | 0  | 0     | 1          | 1      | 0  | 0  | 0          | 0  | 0    | 0    |
| Bits  | 15      | 14      | 13 | 12 | 11     | 10 | 9  | 8     | 7          | 6      | 5  | 4  | 3          | 2  | 1    | 0    |
| R     | 0       | 0       | 0  |    | RXIDEN |    |    | TXOFE | TXFIFOSIZE |        |    |    | RXFIFOSIZE |    |      |      |
| W     | TXFLUSH | RXFLUSH |    |    |        |    |    | RXOFE |            |        |    |    |            |    |      |      |
| Reset | 0       | 0       | 0  | 0  | 0      | 0  | 0  | 0     | 0          | 0      | 0  | 1  | 0          | 0  | 0    | 1    |

**Fields**

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 23<br>TXEMPT | <p>Transmit FIFO Or Buffer Empty</p> <p>Indicates whether the transmit buffer is empty.</p> <p>This field becomes 1 when there is no data in the transmit FIFO or buffer. The field does not consider data in the transmit shift register.</p> <p>0b - Not empty</p> <p>1b - Empty</p>                                                                                                                                                                                                                                                      |
| 22<br>RXEMPT | <p>Receive FIFO Or Buffer Empty</p> <p>Indicates whether the receive buffer is empty.</p> <p>This field becomes 1 when there is no data in the receive FIFO or buffer. The field does not consider data in the receive shift register.</p> <p>0b - Not empty</p> <p>1b - Empty</p>                                                                                                                                                                                                                                                          |
| 21-18<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 17<br>TXOF   | <p>Transmitter FIFO Overflow Flag</p> <p>Indicates whether more data has been written to the transmit FIFO than it can hold.</p> <p>If this field is 0, no transmit FIFO overflow has occurred since the last time the field was cleared, and if this field is 1, at least one transmit FIFO overflow has occurred since the last time the field was cleared.</p> <p>This field becomes 1 regardless of the value of <a href="#">FIFO[TXOFE]</a>. However, an interrupt is issued to the host only if <a href="#">FIFO[TXOFE]</a> is 1.</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | <p style="text-align: center;"><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - No overflow</li> <li>1b - Overflow</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 16<br>RXUF    | <p>Receiver FIFO Underflow Flag</p> <p>Indicates whether more data has been read from the receive FIFO than was present.</p> <p>If this field is 0, no receive FIFO underflow has occurred since the last time the field was cleared, and if this field is 1, at least one receive FIFO underflow has occurred since the last time the field was cleared.</p> <p>This field becomes 1 regardless of the value of <a href="#">FIFO[RXUFE]</a>. However, an interrupt is issued to the host only if <a href="#">FIFO[RXUFE]</a> is 1.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - No underflow</li> <li>1b - Underflow</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul> |
| 15<br>TXFLUSH | <p>Transmit FIFO Flush</p> <p>Causes all data that is stored in the transmit FIFO to be flushed.</p> <p>If you write 0 to this field, no flush operation occurs, and if you write 1 to this field, all data in the transmit FIFO or buffer clears out.</p> <p>This does not affect data in the transmit shift register.</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - All data flushed out</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 14<br>RXFLUSH | <p>Receive FIFO Flush</p> <p>Causes all data that is stored in the receive FIFO to be flushed.</p> <p>If you write 0 to this field, no flush operation occurs, and if you write 1 to this field, all data in the receive FIFO or buffer clears out.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | <p>This does not affect data in the receive shift register.</p> <p>0b - No effect<br/>1b - All data flushed out</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 13<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 12-10<br>RXIDEN | <p>Receiver Idle Empty Enable</p> <p>Enables <a href="#">STAT[RDRF]</a> to become 1 when the receiver is idle for a number of idle characters and the FIFO is not empty.</p> <p>000b - Disable STAT[RDRF] to become 1 because of partially filled FIFO when the receiver is idle<br/>001b - Enable STAT[RDRF] to become 1 because of partially filled FIFO when the receiver is idle for one character<br/>010b - Enable STAT[RDRF] to become 1 because of partially filled FIFO when the receiver is idle for two characters<br/>011b - Enable STAT[RDRF] to become 1 because of partially filled FIFO when the receiver is idle for four characters<br/>100b - Enable STAT[RDRF] to become 1 because of partially filled FIFO when the receiver is idle for eight characters<br/>101b - Enable STAT[RDRF] to become 1 because of partially filled FIFO when the receiver is idle for 16 characters<br/>110b - Enable STAT[RDRF] to become 1 because of partially filled FIFO when the receiver is idle for 32 characters<br/>111b - Enable STAT[RDRF] to become 1 because of partially filled FIFO when the receiver is idle for 64 characters</p> |
| 9<br>TXOFE      | <p>Transmit FIFO Overflow Interrupt Enable</p> <p>Enables <a href="#">FIFO[TXOF]</a> to generate an interrupt to the host.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 8<br>RXUFE      | <p>Receive FIFO Underflow Interrupt Enable</p> <p>Enables <a href="#">FIFO[RXUF]</a> to generate an interrupt to the host.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7<br>TXFE       | <p>Transmit FIFO Enable</p> <p>Enables the transmit FIFO.</p> <p>If this field is 0, the transmit buffer operates as a FIFO of depth equal to 1 dataword, regardless of the value in <a href="#">FIFO[TXFIFOSIZE]</a>. Both <a href="#">CTRL[TE]</a> and <a href="#">CTRL[RE]</a> must be 0 before you change the value of this field.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | <p>If this field is 1, the built-in FIFO structure for the transmit buffer is enabled. <a href="#">FIFO[TXFIFOSIZE]</a> indicates the size of the FIFO structure.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                                                                                        |
| 6-4<br>TXFIFOSIZE | <p>Transmit FIFO Buffer Depth</p> <p>Indicates the maximum number of transmit datawords (transmit FIFO buffer depth) that can be stored in the transmit buffer.</p> <p>000b - 1<br/>001b - 4<br/>010b - 8<br/>011b - 16<br/>100b - 32<br/>101b - 64<br/>110b - 128<br/>111b - 256</p>                                                                                                                                                                                                                                                            |
| 3<br>RXFE         | <p>Receive FIFO Enable</p> <p>Enables the receive FIFO.</p> <p>If this field is 0, the receive buffer operates as a FIFO of depth equal to 1 dataword, regardless of the value in <a href="#">FIFO[RXFIFOSIZE]</a>. Both <a href="#">CTRL[RE]</a> and <a href="#">CTRL[TE]</a> must be 0 before you change the value of this field.</p> <p>If this field is 1, the built-in FIFO structure for the receive buffer is enabled. <a href="#">FIFO[RXFIFOSIZE]</a> indicates the size of the FIFO structure.</p> <p>0b - Disable<br/>1b - Enable</p> |
| 2-0<br>RXFIFOSIZE | <p>Receive FIFO Buffer Depth</p> <p>Indicates the maximum number of receive datawords (receive FIFO buffer depth) that can be stored in the receive buffer before an overrun occurs.</p> <p>000b - 1<br/>001b - 4<br/>010b - 8<br/>011b - 16<br/>100b - 32<br/>101b - 64<br/>110b - 128<br/>111b - 256</p>                                                                                                                                                                                                                                       |

### 37.6.1.13 Watermark (WATER)

#### Offset

| Register | Offset |
|----------|--------|
| WATER    | 2Ch    |

#### Function

Provides the ability to set a programmable threshold for notification, or sets the programmable thresholds to indicate that transmit data can be written or receive data can be read.

You may read this register at any time but must write to it only when [CTRL\[TE\]](#) is 0.

#### Diagram

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16      |
|-------|----|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|---------|
| R     |    |    |    |    | 0  |    |    |    | RXCOUNT |    |    |    | 0  |    |    |         |
| W     |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    | RXWATER |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0       |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0       |
| R     |    |    |    |    | 0  |    |    |    | TXCOUNT |    |    |    | 0  |    |    |         |
| W     |    |    |    |    |    |    |    |    |         |    |    |    |    |    |    | TXWATER |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0       |

#### Fields

| Field            | Function                                                                                                                                                                                                                                                                                                                                                    |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-27<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                    |
| 26-24<br>RXCOUNT | Receive Counter<br>Indicates the number of datawords in the receive FIFO or buffer.<br>If a dataword is being received in the receive shift register, it is not included in the count. This value may be used in conjunction with <a href="#">FIFO[RXFIFOSIZE]</a> to calculate the room left in the receive FIFO or buffer.                                |
| 23-18<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                    |
| 17-16<br>RXWATER | Receive Watermark<br>Generates an interrupt or a DMA request if the number of datawords in the receive FIFO or buffer is greater than the value of this field.<br>For proper operation, the value of this field must be less than the size of the receive FIFO or buffer, as indicated by <a href="#">FIFO[RXFIFOSIZE]</a> and <a href="#">FIFO[RXFE]</a> . |

Table continues on the next page...

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-11<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                |
| 10-8<br>TXCOUNT | <p>Transmit Counter</p> <p>Indicates the number of datawords in the transmit FIFO or buffer.</p> <p>If a dataword is being transmitted to the transmit shift register, it is not included in the count. This value may be used in conjunction with the value of <a href="#">FIFO[TXFIFOSIZE]</a> to calculate the room left in the transmit FIFO or buffer.</p>                         |
| 7-2<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                |
| 1-0<br>TXWATER  | <p>Transmit Watermark</p> <p>Generates an interrupt or a DMA request when the number of datawords in the transmit FIFO or buffer is equal to or less than the value of this field.</p> <p>For proper operation, the value of this field must be less than the size of the transmit buffer or FIFO, as indicated by <a href="#">FIFO[TXFIFOSIZE]</a> and <a href="#">FIFO[TXFE]</a>.</p> |

### 37.6.1.14 Data Read-Only (DATARO)

#### Offset

| Register | Offset |
|----------|--------|
| DATARO   | 30h    |

#### Function

Indicates the first entry in the receive FIFO, but does not pull data from the FIFO.

#### Diagram

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

**Fields**

| Field        | Function                                                                                                                                              |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—   | Reserved                                                                                                                                              |
| 15-0<br>DATA | Receive Data<br>Indicates the first entry from the receive FIFO.<br>This register has the same functionality as that of <a href="#">Data (DATA)</a> . |

# Chapter 38

## Low Power Serial Peripheral Interface (LPSPI)

### 38.1 Chip-specific LPSPI information

Table 217. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | LPSPI          | <a href="#">LPSPI</a>               |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 38.1.1 Module instances

This device supports two instances of LPSPI: LPSPI0 and LPSPI1.

### 38.2 Overview

LPSPI provides an efficient interface (either as a master or slave) to an SPI bus, which is a synchronous serial communication interface used in embedded systems. It is typically used to perform short distance communications between microcontrollers and peripheral devices, on printed circuit boards. Typical applications include interfacing with secure digital cards and LCD displays.

### 38.2.1 Block diagram



Figure 167. Block diagram

### 38.2.2 Features

- Minimal CPU overhead, with DMA transmit and receive requests supporting FIFO register accesses
- Operation continues in Deep Sleep mode, if configured to do so and an appropriate clock is available
- Support available for 32-bit word size
- Configurable clock polarity and phase
- Support available for 4 peripheral chip selects in Master mode
- Support available for Slave mode
- 4-word transmit and command FIFO
- 4-word receive FIFO
- Flexible timing parameters in Master mode, including SCK frequency and duty cycle, and delays between PCS and SCK edges
- Continuous transfer option to keep PCS asserted across multiple frames
- Full-duplex transfers that support 1-bit transmit and receive on each clock edge
- Half-duplex transfers that support:
  - 1-bit transmit or receive on each clock edge
  - 2-bit transmit or receive on each clock edge
  - 4-bit transmit or receive on each clock edge

- Option to use host request to control the start of an SPI bus transfer
- Receive data match logic that discards nonmatching data and interrupt on data match

### 38.3 Functional description

#### 38.3.1 Master mode

##### 38.3.1.1 Transmit and command FIFO commands

The transmit and command FIFO is a combined FIFO that includes both transmit data words and command words. You store:

- Transmit data words in the transmit and command FIFO, by writing to [Transmit Data \(TDR\)](#).
- Command words in the transmit and command FIFO, by writing to [Transmit Command \(TCR\)](#).

When a command word is at the top of the transmit and command FIFO, the actions that can occur depend on whether LPSPI is busy or between frames (see [TCR\[CONT\]](#) and [TCR\[CONTC\]](#)). See [Table 218](#) for conditions and possible corresponding actions when a command word is at the top of the transmit and command FIFO.

**Table 218. Possible actions when a command word is at the top of the transmit and command FIFO**

| Condition                                                                                                           | Action                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LPSPI is enabled and idle.                                                                                          | The command word is pulled from the FIFO, and this command word controls all subsequent transfers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| LPSPI is busy and <a href="#">TCR[CONTC]</a> is 0.                                                                  | The SPI frame completes at the end of the existing word, ignoring <a href="#">TCR[FRAMESZ]</a> . The command word is then pulled from the FIFO and that command word controls all subsequent transfers (or until the next update to the command word). Note that a command word with <a href="#">TCR[CONTC]</a> = 0 always terminates the existing transfer regardless of the previous <a href="#">TCR[CONT]</a> value.                                                                                                                                                                                                              |
| LPSPI is busy; the existing <a href="#">TCR[CONT]</a> value is 1 and the new <a href="#">TCR[CONTC]</a> value is 1. | The command word must be updated at the frame boundary. The command word is pulled from the FIFO during the last SCK pulse of the existing frame (based on the value of <a href="#">FRAMESZ</a> ), and the frame continues using the new command value for the rest of the frame (or until the next update to the command word). When <a href="#">TCR[CONTC]</a> = 1, only the lower 24 bits of the command word are updated. If the command word is updated at a word boundary, then the transfer halts (stops) after that word. <a href="#">TCR[CONTC]</a> is ignored when not at a frame boundary, so the frame ends prematurely. |

[TCR\[CONT\]](#) = 1 keeps PCS asserted at end of frame, allowing the transfer to continue.

[TCR\[CONTC\]](#) = 1 specifies that this command word must not terminate the existing frame, and the transfer can continue using the new command word.

[TCR\[CONTC\]](#) = 1 is restricted in the sense that the new command must load on a frame boundary, and the only way for a transfer to continue from a frame boundary is when the previous command has [TCR\[CONT\]](#) = 1.

You can read the current state of the existing command word from [Transmit Command \(TCR\)](#). It requires at least three LPSPI functional clock cycles for [Transmit Command \(TCR\)](#) to update after you write to it (assuming an empty FIFO), and LPSPI must be enabled ([CR\[MEN\]](#) = 1).

Writing to [Transmit Command \(TCR\)](#) does not initiate an SPI bus transfer, unless [TCR\[TXMSK\]](#) = 1. When [TCR\[TXMSK\]](#) = 1, a new command word is not loaded until the end of the existing frame (based on the value of [TCR\[FRAMESZ\]](#)); at the end of the transfer, [TCR\[TXMSK\]](#) transitions to 0.

In Master mode, the LPSPI command word in [Transmit Command \(TCR\)](#) controls SPI attributes based on the selections in register fields. See [Table 219](#) for TCR fields and associated functionality related to data transfer.

Table 219. Command word in Master mode

| Transmit Command (TCR) |                        | Description                                                                                                                                                                                                                                                                                                                                                             | Can this field be modified during a data transfer? |
|------------------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|
| Field                  | Name                   |                                                                                                                                                                                                                                                                                                                                                                         |                                                    |
| CPOL                   | Clock polarity         | Specifies the polarity of the SCK pin. Any change of CPOL value causes a transition on the SCK pin.                                                                                                                                                                                                                                                                     | N                                                  |
| CPHA                   | Clock phase            | Specifies the clock phase of the transfer.                                                                                                                                                                                                                                                                                                                              | N                                                  |
| PRESCALE               | Prescaler value        | Specifies a prescaler used to divide the LPSPI functional clock, to generate the timing parameters of the SPI bus transfer. Changing PRESCALE in conjunction with PCS enables LPSPI to connect to different slave devices at different frequencies.                                                                                                                     | N                                                  |
| PCS                    | Peripheral chip select | Specifies which PCS pin asserts for the transfer; the polarity of PCS is static and specified by <a href="#">CFG1[PCSPOL]</a> .<br><br>If <a href="#">CFG1[PCSCFG]</a> = 1, do not select PCS[3:2].                                                                                                                                                                     | N                                                  |
| LSBF                   | LSB first              | Specifies whether LSB (bit 0) or MSB (bit 31 for a 32-bit word) is transmitted or received first.                                                                                                                                                                                                                                                                       | Y                                                  |
| BYSW                   | Byte swap              | Enables byte swap on each 32-bit word when transmitting and receiving data. Byte swapping can be useful when interfacing with devices that organize data as big-endian.                                                                                                                                                                                                 | Y                                                  |
| CONT                   | Continuous transfer    | Configures LPSPI for a continuous transfer that keeps PCS asserted between frames (as specified by FRAMESZ). You must write a new command word to cause PCS to negate. Also, this field supports changing the command word at frame size boundaries.                                                                                                                    | Y                                                  |
| CONTC                  | Continuing command     | Indicates that this is a new command word for the existing continuous transfer. When CONTC = 1, the command word must only be written to the transmit and command FIFO on a frame boundary.                                                                                                                                                                             | Y                                                  |
| RXMSK                  | Receive data mask      | Masks the receive data and does not store the masked receive data in the receive FIFO or perform receive data matching. This option is useful for half-duplex transfers or to specify which fields are compared during receive data matching.                                                                                                                           | Y                                                  |
| TXMSK                  | Transmit data mask     | Masks the transmit data; masked transmit data is not pulled from the transmit FIFO, and the output data pin is 3-stated (unless otherwise configured by <a href="#">CFG1[OUTCFG]</a> ). This option is useful for half-duplex transfers.                                                                                                                                | Y                                                  |
| WIDTH                  | Transfer width         | Specifies the number of bits shifted on each SCK pulse: <ul style="list-style-type: none"> <li>• 1-bit transfers support traditional SPI bus transfers in either half-duplex or full-duplex data formats.</li> <li>• 2-bit and 4-bit half-duplex transfers are useful for interfacing with QuadSPI memory devices, and either TXMSK or RXMSK must also be 1.</li> </ul> | Y                                                  |
| FRAMESZ                | Frame size             | Configures the frame size in number of bits equal to (FRAMESZ + 1):                                                                                                                                                                                                                                                                                                     | Y                                                  |

*Table continues on the next page...*

Table 219. Command word in Master mode (continued)

| Transmit Command (TCR) |      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Can this field be modified during a data transfer? |
|------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|
| Field                  | Name |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                    |
|                        |      | <ul style="list-style-type: none"> <li>The minimum frame size is 8 bits.</li> <li>If the frame size is larger than 32 bits, then the frame is divided into multiple words of 32 bits; each word is loaded from the transmit FIFO and stored in the receive FIFO separately.</li> <li>If the size of the frame is not divisible by 32, then the last load of the transmit FIFO and store of the receive FIFO contains the remaining bits. For example, a 72-bit transfer consists of three words: the first and second words are 32 bits, and the third word is 8 bits.</li> </ul> |                                                    |

### 38.3.1.1.1 SPI bus transfers

LPSPI initiates an SPI bus transfer when all these conditions are true:

- Data is written to the transmit FIFO.
- The HREQ pin is asserted (or the HREQ function is disabled).
- LPSPI is enabled.

To perform the SPI bus transfer, LPSPI uses the attributes configured in [Transmit Command \(TCR\)](#) and the timing parameters defined in [Clock Configuration \(CCR\)](#).

The SPI bus transfer ends after the number of bits indicated by the value of [FRAMESZ](#) have been transferred (provided [CONT](#) = 0), or at the end of a word when a new transmit command word is at the top of the transmit and command FIFO. When LPSPI is disabled, the SPI bus transfers end after the transmit FIFO is empty and LPSPI is idle.

The HREQ input is only checked when PCS is negated.

### 38.3.1.1.2 Circular FIFO

The transmit and command FIFO supports a circular FIFO feature. This feature enables the LPSPI master to (periodically) repeat a short data transfer that fits within the transmit and command FIFO, without requiring additional FIFO accesses. When the circular FIFO is enabled ([CFGRO\[CIRFIFO\]](#) = 1), the current state of the FIFO read pointer is saved and the status flags are not updated. After the FIFO is empty and LPSPI is idle, the FIFO read pointer is restored with the saved version, so the contents of the transmit and command FIFO are not permanently pulled from the FIFO when Circular FIFO mode is enabled.

### 38.3.1.2 Receive FIFO and data match

The receive FIFO stores received data during SPI bus transfers. When [TCR\[RXMSK\]](#) = 1, the received data is discarded instead of being stored in the receive FIFO:

- Received data is written to the receive FIFO when the last bit of the word is sampled.
- If the transmit FIFO is empty during a multiple-word or continuous transfer, then the receive data is written to the receive FIFO before the transfer stalls (assuming [CFG1\[NOSTALL\]](#) = 0) while waiting for new transmit data or for a command word to be written.

LPSPI provides a receive data match function that can match received data against one of the two words in [DMR0](#) and [DMR1](#), or against a masked data word. You can also configure the received data match function to compare only the first one or two received data words since the start of the frame:

- Received data that is already discarded because of [TCR\[RXMSK\]](#) cannot cause the data match flag to set, and delays the receive data match on the first received data word, until all discarded data is received.

- You can configure the receive data match function to discard all received data until a data match is detected, using [CFGRO\[RDMO\]](#).
- After a receive data match, to allow all subsequent data to be received, write 0 to CFGRO[RDMO], and then write 0 to [SR\[DMF\]](#).

### 38.3.1.3 Timing parameters

The timing parameters that are used for all SPI bus transfers are relative to the LPSPI functional clock divided by the selection specified in [TCR\[PRESCALE\]](#). Although you cannot change [Clock Configuration \(CCR\)](#) when LPSPI is busy, to support interfacing with different slave devices at different frequencies, you can change the TCR[PRESCALE] selection between SPI bus transfers by using [Transmit Command \(TCR\)](#).

**NOTE**

The minimum value shown in [Table 220](#) is the minimum counter value, but the values of [Clock Configuration \(CCR\)](#) must also satisfy the data sheet specs based on the LPSPI functional clock frequency and prescaler value.

**Table 220. Timing parameters**

| <a href="#">Clock Configuration (CCR)</a><br><a href="#">Clock Configuration 1 (CCR1)</a> |                  | <b>Description</b>                                                                                                                                                                                                                                                                                                 | <b>Minimum value</b> | <b>Maximum value</b> |
|-------------------------------------------------------------------------------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|----------------------|
| <b>Field</b>                                                                              | <b>Name</b>      |                                                                                                                                                                                                                                                                                                                    |                      |                      |
| <a href="#">SCKSET</a>                                                                    | SCK setup phase  | Configures the SCK setup phase to (SCKSET + 1) cycles. The setup phase is the SCK high period when either CPHA = 0 and CPOL = 1, or CPHA = 1 and CPOL = 0. Otherwise, it is the SCK low period. The SCK period is defined as (SCKSET + SCKHLD + 2) and the duty cycle is the difference between SCKSET and SCKHLD. | 0 (1 cycle)          | 255 (256 cycles)     |
| <a href="#">SCKHLD</a>                                                                    | SCK hold phase   | Configures the SCK hold phase to (SCKHLD + 1) cycles. The hold phase is the SCK low period when either CPHA = 0 and CPOL = 1, or CPHA = 1 and CPOL = 0. Otherwise, it is the SCK high period. The SCK period is defined as (SCKSET + SCKHLD + 2) and the duty cycle is the difference between SCKSET and SCKHLD.   | 0 (1 cycle)          | 255 (256 cycles)     |
| <a href="#">PCSPCS</a>                                                                    | PCS-to-PCS delay | Configures the minimum delay between PCS negation and the next PCS assertion to (PCSPCS + PCSPCS + 2) cycles. When the command word is updated between transfers, there is a minimum of (PCSPCS + 1) cycles between the command word update and any change on PCS pins.                                            | 0 (2 cycles)         | 255 (512 cycles)     |
| <a href="#">SCKSCK</a>                                                                    | SCK-to-SCK delay | Configures the delay during a continuous transfer between the last SCK edge of a frame and the first SCK edge of the continuing frame to (SCKSCK + 1) cycles. This is useful when the external slave requires a large delay between different words of an SPI bus transfer.                                        | 0 (1 cycle)          | 255 (256 cycles)     |

*Table continues on the next page...*

Table 220. Timing parameters (continued)

| Clock Configuration (CCR) |                  | Description                                                                                         | Minimum value | Maximum value    |
|---------------------------|------------------|-----------------------------------------------------------------------------------------------------|---------------|------------------|
| Field                     | Name             |                                                                                                     |               |                  |
| PCSSCK                    | PCS-to-SCK delay | Configures the minimum delay between PCS assertion and the first SCK edge to (PCSSCK + 1) cycles.   | 0 (1 cycle)   | 255 (256 cycles) |
| SCKPCS                    | SCK-to-PCS delay | Configures the minimum delay between the last SCK edge and the PCS negation to (SCKPCS + 1) cycles. | 0 (1 cycle)   | 255 (256 cycles) |

Figure 168 shows the timing settings controlled by:

- [TCR\[CPHA\]](#)
- [TCR\[CPOL\]](#)
- [CCR\[SCKPCS\]](#)
- [CCR\[PCSSCK\]](#)
- [CCR1\[SCKSET\]](#)
- [CCR1\[SCKHLD\]](#)



Figure 168. Clock phase (TCR[CPHA]) timing diagram example

To configure for a baud rate of 10 MHz with 50/50 duty cycle and with a functional clock frequency of 100 MHz, use the following settings:

- CCR1[SCKSET] = 0x4 (5 cycles)
- CCR1[SCKHLD] = 0x4 (5 cycles)
- CCR1[PCSPCS] = 0x8 (10 cycles)
- CCR1[SCKSCK] = 0x4 (5 cycles)
- CRR[PCSSCK] = 0x4 (5 cycles)
- CRR[SCKPCS] = 0x4 (5 cycles)
- TCR[PRESCALE] = 0x0 (divide by 1)

### 38.3.1.4 Pin configuration

Following are the pin configuration settings for half-duplex transfers:

- To swap directions or to support half-duplex transfers on the same pin, you can configure the SIN and SOUT pins using [CFG1\[PINCFG\]](#).
- To specify whether an output data pin (SOUT, for example) 3-states when PCS is negated, or if the output data pin retains the last value, use [CFG1\[OUTCFG\]](#).
- When configuring half-duplex transfers, you must configure the output data pins to 3-state when PCS is negated (CFG1[OUTCFG] = 1).
- When performing half-duplex 2-bit transfers, you can write any value to [CFG1\[PCSCFG\]](#).
- When performing half-duplex 4-bit transfers, you must write 1h to CFG1[PCSCFG].

### 38.3.1.5 Clock loopback

Configure the LPSPI master to use one of the following clocks to sample the input data:

- The SCK output clock
- A delayed version of the SCK output clock

The delayed version of the SCK is chosen by the SCK pin output delay, plus the SCK pin input delay, and is selected by writing 1 to [CFG1\[SAMPLE\]](#). Enabling the loopback version of the SCK pin can improve the setup time of the input data from the slave.

See the chip data sheet for the specific input setup time in Master Loopback mode.



Figure 169. Clock loopback

## 38.3.2 Slave mode

LPSPI Slave mode:

- Uses the same shift register and logic that Master mode uses.
- Does not use [Clock Configuration \(CCR\)](#).
- Requires [Transmit Command \(TCR\)](#) to remain static (unchanged) during SPI bus transfers.

### 38.3.2.1 Transmit and command FIFO commands

You must initialize [Transmit Command \(TCR\)](#) before enabling LPSPI in Slave mode, although this register is not updated until after LPSPI is enabled. After LPSPI is enabled, you must make changes to this register only when LPSPI is idle. In Slave mode, the LPSPI command word in this register controls SPI attributes. Before the PCS input asserts, the transmit FIFO must be filled with transmit data, or the transmit error flag sets.

Table 221. Command word in Slave mode

| Transmit Command (TCR) |                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------------|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Field                  | Name                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| CPOL                   | Clock polarity         | Specifies the polarity of the external SCK input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| CPHA                   | Clock phase            | Specifies the clock phase of transfer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| PRESCALE               | Prescaler value        | Specifies the LPSPI functional clock prescaler.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| PCS                    | Peripheral chip select | Specifies which PCS is used. The polarity of PCS is static and configured by <a href="#">CFG1[PCSPOL]</a> .<br>If <a href="#">CFG1[PCSCFG]</a> is not equal to zero, then do not select the PCS[3:2] pins.                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| LSBF                   | LSB first              | Specifies whether LSB (bit 0) or MSB (bit 31 for a 32-bit word) is transmitted or received first.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| BYSW                   | Byte swap              | Enables byte swap on each 32-bit word when transmitting and receiving data. Byte swapping can be useful when interfacing with devices that organize data as big-endian.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| CONT                   | Continuous transfer    | When continuous transfer is selected in Slave mode, after the number of bits indicated by FRAMESZ are transferred, LPSPI passes through and transmits the received data until the next PCS negation. Whatever is shifted in on the receive data is shifted out as transmit data considering that there is a 32-bit shift register.                                                                                                                                                                                                                                                                                                                  |
| CONTC                  | Continuing command     | When the continuing command is enabled in Slave mode, after the number of bits indicated by FRAMESZ are transferred, RXMSK is considered equal to 1 and TXMSK is considered equal to 0 until the next PCS negation. CONTC can be used to change the direction of a transfer after the number of bits indicated by FRAMESZ.                                                                                                                                                                                                                                                                                                                          |
| RXMSK                  | Receive data mask      | Masks the receive data; LPSPI does not store masked receive data in the receive FIFO or perform receive data matching. This option is useful for half-duplex transfers or to specify which fields are compared during receive data matching.                                                                                                                                                                                                                                                                                                                                                                                                        |
| TXMSK                  | Transmit data mask     | Masks the transmit data so that the masked transmit data is not pulled from transmit FIFO, and the output data pin is 3-stated (unless otherwise specified in <a href="#">CFG1[OUTCFG]</a> ). This option is useful for half-duplex transfers.                                                                                                                                                                                                                                                                                                                                                                                                      |
| WIDTH                  | Transfer width         | Specifies the number of bits shifted on each SCK pulse: <ul style="list-style-type: none"> <li>1-bit transfers support traditional SPI bus transfers in either half-duplex or full-duplex data formats.</li> <li>2-bit and 4-bit half-duplex transfers are useful for interfacing with QuadSPI memory devices, and at least either TCR[TXMSK] or TCR[RXMSK] must be 1.</li> </ul>                                                                                                                                                                                                                                                                   |
| FRAMESZ                | Frame size             | Specifies the frame size in number of bits equal to (FRAMESZ + 1): <ul style="list-style-type: none"> <li>The minimum frame size is 8 bits.</li> <li>If the frame size is larger than 32 bits, then the frame is divided into multiple words of 32 bits; each word is loaded from the transmit FIFO and stored in the receive FIFO separately.</li> <li>If the size of the frame is not divisible by 32, then the last load of the transmit FIFO and store of the receive FIFO contain the remainder bits. For example, a 72-bit transfer consists of three words: the first and second words are 32 bits, and the third word is 8 bits.</li> </ul> |

### 38.3.2.2 Receive FIFO and data match

The receive FIFO stores receive data during SPI bus transfers. When [TCR\[RXMSK\]](#) = 1, the received data is discarded instead of storing the received data in the receive FIFO.

Receive data supports a receive data match function that can match received data against one of the two words in [DMR0](#) and [DMR1](#) or against a masked data word. You can also configure the data match function to compare only the first one or two received data words since the start of the frame:

- Received data that is already discarded because TCR[RXMSK] = 1 cannot cause the data match to set, and delays the match on the first received data word, until all discarded data is received.
- By using [CFG0\[RDMO\]](#), you can also configure the receiver match function to discard all received data until a data match is detected.
- After a receive data match, to allow all subsequent data to be received, first write 0 to CFG0[RDMO], then clear [SR\[DMF\]](#).

### 38.3.2.3 Partial received word

When the PCS pin deasserts and the receive shift register shifts in a partial word, you can configure the receive shift register to either discard the partial word or to store it in the receive FIFO. You must specify this using [CFG1\[PARTIAL\]](#).

A partial word is defined as less than [TCR\[FRAMESZ\]](#) bits (when TCR[FRAMESZ] is equal or less than 32 bits, or it is the last word in a multi-word frame) or less than 32 bits (when TCR[FRAMESZ] is greater than 32 bits and not the last word in a multi-word frame).

A single-bit frame is not supported. A partial received word of 1 bit is supported, but a partial received frame of 1 bit is not supported.

### 38.3.2.4 Clocked interface

LPSPI supports interfacing with external masters that provide only clock and data pins (PCS is not required). This interface requires:

- Writing 1 to [TCR\[CPHA\]](#) (data is changed on the leading edge of SCK and captured on the following edge).
- Configuring the PCS input to be always asserted ([CFG1\[PCSPOL \$n\$ \]](#) = 1). For example, to configure PCS[0] to be always asserted, write 1 to PCSPOL[0], and do not configure PCS[0] in the pin muxing. The chip-level drives PCS to a certain value (ideally 1); you could use CFG1[PCSPOL $n$ ] to invert that value.
- Writing 1 to [CFG1\[AUTOPCS\]](#) to enable automatic PCS generation. When CFG1[AUTOPCS] = 1, a minimum of four LPSPI functional clock cycles (divided by the selection specified in [TCR\[PRESCALE\]](#)) is required between the last SCK edge of one word and the first SCK edge of the next word.

### 38.3.3 Low-power modes

Table 222. Low-power modes

| Chip mode                               | LPSPI operation                                                                                                                                |
|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| Run                                     | Normal operation                                                                                                                               |
| Deep Sleep                              | Can continue operating in Deep Sleep mode if LPSPI is using an external or internal clock source that remains operating during Deep Sleep mode |
| Low-Power-Stop (also called Deep Sleep) | Waits for the current transfer to complete any pending operation, before entering Low-Power-Stop mode                                          |

### 38.3.4 Debug mode

Table 223. Debug mode

| Chip mode                                   | LPSPI operation                                                        |
|---------------------------------------------|------------------------------------------------------------------------|
| Debug (the core is in Debug or Halted mode) | Can continue operating in Debug mode, if <a href="#">CR[DBGEN]</a> = 1 |

### 38.3.5 Clocking

Table 224. LPSPI clocks

| Type of clock | Description                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Functional    | <ul style="list-style-type: none"> <li>Asynchronous to the bus clock.</li> <li>If the LPSPI functional clock remains enabled in low-power modes, then LPSPI can perform SPI bus transfers and low-power wakeups in both Master and Slave modes.</li> <li>LPSPI divides the functional clock by a prescaler; the resulting frequency must be at least two times faster than the SPI external clock frequency (SCK).</li> </ul> |
| External      | <ul style="list-style-type: none"> <li>The LPSPI shift register is clocked directly by the SCK clock.</li> <li>How the SCK clock is generated or supplied depends on the mode (Master or Slave): <ul style="list-style-type: none"> <li>In Master mode, the SCK clock is generated internally.</li> <li>In Slave mode, the SCK clock is supplied externally.</li> </ul> </li> </ul>                                           |
| Bus           | The bus clock is only used for bus accesses to the LPSPI control and configuration registers. The bus clock frequency must be high enough to support the data bandwidth requirements of the LPSPI registers, including the FIFOs.                                                                                                                                                                                             |

See the chip-specific LPSPI information for more.

### 38.3.6 Reset

Table 225. LPSPI resets

| Type of reset | Description                                                                                                                                                                                                                          |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Chip          | Resets the LPSPI logic and registers to their default states.                                                                                                                                                                        |
| Software      | <ul style="list-style-type: none"> <li>Resets the LPSPI logic and registers to their default states, except for the Control register.</li> <li>The LPSPI software reset is controlled using <a href="#">CR[RST]</a>.</li> </ul>      |
| FIFO          | <ul style="list-style-type: none"> <li>Resets the transmit and command FIFO and the receive FIFO.</li> <li><a href="#">CR[RTF]</a> and <a href="#">CR[RRF]</a> are write-only.</li> <li>After being reset, FIFO is empty.</li> </ul> |

### 38.3.7 Interrupts and DMA requests

The following table lists Slave mode sources (status flags) that can generate LPSPI interrupts and LPSPI slave transmit and receive DMA requests.

Table 226. Interrupts and DMA requests

| Status (SR) |                        | Description                                                                                                                                                              | Can generate |              |                    |
|-------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|--------------------|
| Status flag | Name                   |                                                                                                                                                                          | Interrupt?   | DMA request? | Low-power wake-up? |
| TDF         | Transmit data flag     | Indicates that data can be written to transmit FIFO, as configured by the transmit FIFO watermark, <a href="#">FCR[TXWATER]</a> .                                        | Y            | TX           | Y                  |
| RDF         | Receive data flag      | Indicates that data can be read from the receive FIFO, as configured by the receive FIFO watermark, <a href="#">FCR[RXWATER]</a> .                                       | Y            | RX           | Y                  |
| WCF         | Word complete flag     | Indicates that the word is complete and the last bit of the word has been sampled.                                                                                       | Y            | N            | Y                  |
| FCF         | Frame complete flag    | Indicates that the frame is complete and PCS is deasserted.                                                                                                              | Y            | RX           | Y                  |
| TCF         | Transfer complete flag | Indicates that transfer is complete, PCS is deasserted, and the transmit and command FIFO is empty.                                                                      | Y            | N            | Y                  |
| TEF         | Transmit error flag    | Indicates a transmit and command FIFO underrun. In Master mode, when <a href="#">CFG1[NOSTALL]</a> = 0 (transfers stall when transmit FIFO is empty), TEF cannot be set. | Y            | N            | Y                  |
| REF         | Receive error flag     | Indicates a receive FIFO overflow. In Master mode, when <a href="#">CFG1[NOSTALL]</a> = 0 (transfers stall when receive FIFO is full), REF cannot be set.                | Y            | N            | Y                  |
| DMF         | Data match flag        | Indicates that the received data matches the configured data match value.                                                                                                | Y            | N            | Y                  |
| MBF         | Module busy flag       | Indicates that LPSPI is busy performing an SPI bus transfer.                                                                                                             | N            | N            | N                  |

### 38.3.7.1 End-of-packet DMA transfer

The end-of-packet functionality is designed for serial interfaces where you may not be aware of the size of the transfer in advance and the data is pushed by an external device. Examples include UART receive, I2C Slave mode, and SPI Slave mode. The end-of-packet processing is intended to ensure that data is not stranded in either the receive FIFO or the DMA receive buffer. Support for end-of-packet processing must be implemented in both the serial interfaces and the DMA controller.

The condition that signals the end of packet is different for each serial interface but the serial peripheral and DMA process it in the same way. For example, UART end of packet is signaled by an idle line condition, I2C end of packet by a stop and/or repeated start condition, and SPI end of packet by PCS negation.

If you configure the serial peripheral to signal the end-of-packet condition to the DMA and the serial interface detects an end-of-packet condition, it asserts the DMA request for the receive FIFO irrespective of the watermark configuration. For larger watermark configurations, this ensures that the last few words of the transfer are first flushed from the receive FIFO.

The DMA then reads the contents of the receive FIFO, depending on the first word in the FIFO:

- If the receive FIFO is empty, the serial interface signals an end-of-packet condition to the DMA controller.
- If the receive FIFO is not empty, but the first word in the FIFO is the start of a new packet, then data is not pulled from the receive FIFO and the serial interface signals an end-of-packet condition to the DMA controller.

- If the receive FIFO is not empty, and the first word in the FIFO is not the start of a new packet, the DMA transfers the receive data as normal.

Because the DMA may be transferring multiple words on each request, the end-of-packet condition persists until the DMA minor loop is complete and no additional data is pulled from the receive FIFO. The status flag that triggered the end-of-packet condition is cleared when the minor loop completes following end of packet being signaled to the DMA controller.

When the DMA detects the end-of-packet condition, it writes all received words up to the end of the packet into the system memory and saves the destination address for the word after the last valid data. The DMA then terminates the channel as if the major loop is complete, including final offsets and optional interrupts, channel linking and scatter/gather. The final destination address can optionally be saved in the system memory or is available in the destination address register.

After the DMA terminates the major loop, no servicing of the receive FIFO occurs until either software or hardware reconfigures the DMA (for example, channel linking or scatter/gather). This delay must be minimized to avoid receiver FIFO overrun. NXP does not recommend automatic DMA end-of-packet processing when there are only a few words transferred between end-of-packet conditions. That is because the DMA spends more time processing the end of packet than transferring the data. For example, the UART idle line length must be increased as needed to avoid an excessive number of idle conditions.

### 38.3.8 Peripheral triggers

The connection of the LPSPI peripheral triggers with other peripherals depends on the device that is used.

Table 227. Peripheral triggers

| Type of trigger | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Additional information                                                                      |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|
| Frame output    | <p>The frame output trigger:</p> <ul style="list-style-type: none"> <li>• Asserts at the end of each frame (when PCS deasserts).</li> <li>• Remains asserted for one cycle of the LPSPI functional clock divided by the configuration defined in <a href="#">TCR[PRESCALE]</a>.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                  | LPSPI generates two output triggers that can be connected to other peripherals on the chip. |
| Word output     | <p>The word output trigger:</p> <ul style="list-style-type: none"> <li>• Asserts at the end of each received word.</li> <li>• Remains asserted for one cycle of the LPSPI functional clock divided by the configuration defined in <a href="#">TCR[PRESCALE]</a>.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                |                                                                                             |
| Input           | <p>To control the start of an LPSPI bus transfer, the LPSPI input trigger can be selected instead of the HREQ input:</p> <ul style="list-style-type: none"> <li>• The LPSPI input trigger is synchronized, and must assert for at least two cycles of the LPSPI functional clock divided by the configuration defined in <a href="#">TCR[PRESCALE]</a> so that the input trigger can be detected.</li> <li>• When LPSPI is busy, the HREQ input (and therefore the LPSPI input trigger) is ignored.</li> <li>• When LPSPI is busy, both the HREQ and LPSPI input triggers are ignored. They are used to start a new transfer when LPSPI is idle.</li> </ul> |                                                                                             |

### 38.4 External signals

Table 228. External signals

| Signal | Name         | Description                                                             | I/O |
|--------|--------------|-------------------------------------------------------------------------|-----|
| SCK    | Serial clock | <ul style="list-style-type: none"> <li>• Input in Slave mode</li> </ul> | I/O |

*Table continues on the next page...*

Table 228. External signals (continued)

| Signal         | Name                                                                | Description                                                                                                                                                                                                                                                                                                                                                     | I/O |
|----------------|---------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
|                |                                                                     | <ul style="list-style-type: none"> <li>• Output in Master mode</li> </ul>                                                                                                                                                                                                                                                                                       |     |
| PCS[0]         | Peripheral chip select                                              | <ul style="list-style-type: none"> <li>• Input in Slave mode</li> <li>• Output in Master mode</li> </ul>                                                                                                                                                                                                                                                        | I/O |
| PCS[1]/HREQ    | Peripheral chip select<br>or<br>host request                        | <p>Host request pin is selected when <b>CFGR0[HREN]</b> = 1 and <b>CFGR0[HRSEL]</b> = 0:</p> <ul style="list-style-type: none"> <li>• Input in either Slave mode or when used as master host request</li> <li>• Output in either Master mode or when used as slave host request</li> </ul>                                                                      | I/O |
| PCS[2]/DATA[2] | Peripheral chip select or data pin 2 during parallel data transfers | <p>When <b>CFGR1[PCSCFG]</b> = 0:</p> <ul style="list-style-type: none"> <li>• Input in Slave mode</li> <li>• Output in Master mode</li> </ul> <p>When <b>CFGR1[PCSCFG]</b> = 1:</p> <ul style="list-style-type: none"> <li>• Input in half-duplex parallel data receive transfers</li> <li>• Output in half-duplex parallel data transmit transfers</li> </ul> | I/O |
| PCS[3]/DATA[3] | Peripheral chip select or data pin 3 during parallel data transfers | <p>When <b>CFGR1[PCSCFG]</b> = 0:</p> <ul style="list-style-type: none"> <li>• Input in Slave mode</li> <li>• Output in Master mode</li> </ul> <p>When <b>CFGR1[PCSCFG]</b> = 1:</p> <ul style="list-style-type: none"> <li>• Input in half-duplex parallel data receive transfers</li> <li>• Output in half-duplex parallel data transmit transfers</li> </ul> | I/O |
| SOUT/DATA[0]   | Serial data output                                                  | Can be configured as serial data input signal (used as data pin 0 in half-duplex parallel data transfers)                                                                                                                                                                                                                                                       | I/O |
| SIN/DATA[1]    | Serial data input                                                   | Can be configured as serial data output signal (used as data pin 1 in half-duplex parallel data transfers)                                                                                                                                                                                                                                                      | I/O |

## 38.5 Initialization

This module does not require initialization.

## 38.6 Memory map and registers

### NOTE

- Writing to a read-only register or reading a write-only register can cause bus errors.
- LPSPI does not check values programmed in registers for validity, so you must take care to write valid values only.

### 38.6.1 LPSPI register descriptions

LPSPI provides an efficient interface to an SPI bus, either as a master or slave. An SPI bus is a synchronous serial communication interface used in embedded systems. It is typically used to perform short distance communications between microcontrollers and peripheral devices, on printed circuit boards. Typical applications include interfacing with secure digital cards and LCD displays.

#### 38.6.1.1 LPSPI memory map

LPSPI0 base address: 4009\_C000h

LPSPI1 base address: 4009\_D000h

| Offset | Register                       | Width<br>(In bits) | Access | Reset value |
|--------|--------------------------------|--------------------|--------|-------------|
| 0h     | Version ID (VERID)             | 32                 | R      | 0200_0004h  |
| 4h     | Parameter (PARAM)              | 32                 | R      | 0004_0202h  |
| 10h    | Control (CR)                   | 32                 | RW     | 0000_0000h  |
| 14h    | Status (SR)                    | 32                 | RW     | 0000_0001h  |
| 18h    | Interrupt Enable (IER)         | 32                 | RW     | 0000_0000h  |
| 1Ch    | DMA Enable (DER)               | 32                 | RW     | 0000_0000h  |
| 20h    | Configuration 0 (CFGRO)        | 32                 | RW     | 0000_0000h  |
| 24h    | Configuration 1 (CFGRI)        | 32                 | RW     | 0000_0000h  |
| 30h    | Data Match 0 (DMR0)            | 32                 | RW     | 0000_0000h  |
| 34h    | Data Match 1 (DMR1)            | 32                 | RW     | 0000_0000h  |
| 40h    | Clock Configuration (CCR)      | 32                 | RW     | 0000_0000h  |
| 44h    | Clock Configuration 1 (CCR1)   | 32                 | RW     | 0000_0000h  |
| 58h    | FIFO Control (FCR)             | 32                 | RW     | 0000_0000h  |
| 5Ch    | FIFO Status (FSR)              | 32                 | R      | 0000_0000h  |
| 60h    | Transmit Command (TCR)         | 32                 | RW     | 0000_001Fh  |
| 64h    | Transmit Data (TDR)            | 32                 | W      | 0000_0000h  |
| 70h    | Receive Status (RSR)           | 32                 | R      | 0000_0002h  |
| 74h    | Receive Data (RDR)             | 32                 | R      | 0000_0000h  |
| 78h    | Receive Data Read Only (RDROR) | 32                 | R      | 0000_0000h  |
| 3FCh   | Transmit Command Burst (TCBR)  | 32                 | W      | 0000_0000h  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset      | Register                              | Width<br>(In bits) | Access | Reset value |
|-------------|---------------------------------------|--------------------|--------|-------------|
| 400h - 5FCh | Transmit Data Burst (TDBR0 - TDBR127) | 32                 | W      | 0000_0000h  |
| 600h - 7FCh | Receive Data Burst (RDBR0 - RDBR127)  | 32                 | R      | 0000_0000h  |

### 38.6.1.2 Version ID (VERID)

#### Offset

| Register | Offset |
|----------|--------|
| VERID    | 0h     |

#### Function

Contains version numbers for the module design and feature set.

#### Diagram

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

#### Fields

| Field   | Function                                                                                                                                                      |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24   | Major Version Number                                                                                                                                          |
| MAJOR   | Indicates the major version number of the module specification.                                                                                               |
| 23-16   | Minor Version Number                                                                                                                                          |
| MINOR   | Indicates the minor version number of the module specification.                                                                                               |
| 15-0    | Module Identification Number                                                                                                                                  |
| FEATURE | Indicates the feature set number<br><br>0000_0000_0000_0100b - Standard feature set supporting a 32-bit shift register.<br><br>All other values are reserved. |

### 38.6.1.3 Parameter (PARAM)

#### Offset

| Register | Offset |
|----------|--------|
| PARAM    | 4h     |

#### Function

Contains:

- Number of PCS pins.
- Receive FIFO size.
- Transmit FIFO size.

#### Diagram



#### Fields

| Field           | Function                                                                                                                        |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------|
| 31-24<br>—      | Reserved                                                                                                                        |
| 23-16<br>PCSNUM | PCS Number<br>Indicates the number of PCS pins supported.                                                                       |
| 15-8<br>RXFIFO  | Receive FIFO Size<br>Indicates the maximum number of words in the receive FIFO. The maximum number of words is $2^{RXFIFO}$ .   |
| 7-0<br>TXFIFO   | Transmit FIFO Size<br>Indicates the maximum number of words in the transmit FIFO. The maximum number of words is $2^{TXFIFO}$ . |

### 38.6.1.4 Control (CR)

#### Offset

| Register | Offset |
|----------|--------|
| CR       | 10h    |

#### Function

Contains fields that control the module operation.

#### Diagram



#### Fields

| Field    | Function                                                                                                                    |
|----------|-----------------------------------------------------------------------------------------------------------------------------|
| 31-10    | Reserved                                                                                                                    |
| —        |                                                                                                                             |
| 9<br>RRF | Reset Receive FIFO<br>Deletes all entries in the receive FIFO. This field always reads 0.<br>0b - No effect<br>1b - Reset   |
| 8<br>RTF | Reset Transmit FIFO<br>Deletes all entries in the transmit FIFO. This field always reads 0.<br>0b - No effect<br>1b - Reset |
| 7-4      | Reserved                                                                                                                    |
| —        |                                                                                                                             |
| 3        | Debug Enable                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                            |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DBGEN    | <p>Enables LPSPI when the CPU is in Debug mode.</p> <p>If this field is 0, LPSPI is disabled when the CPU is halted; the PCS pin is deasserted after the transmit FIFO is empty regardless of the state of <a href="#">Transmit Command (TCR)</a>.</p> <p>You must update this field only when LPSPI is disabled (<a href="#">MEN</a> = 0).</p> <p>0b - Disable<br/>1b - Enable</p> |
| 2<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                            |
| 1<br>RST | <p>Software Reset</p> <p>Resets all internal logic and registers, except <a href="#">Control (CR)</a>. The reset takes effect immediately and remains asserted until you write 0 to it. There is no minimum delay required before clearing the software reset by writing 0.</p> <p>0b - Not reset<br/>1b - Reset</p>                                                                |
| 0<br>MEN | <p>Module Enable</p> <p>Enables the module. After writing 0, MEN remains set until LPSPI has completed the current transfer and is idle.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                    |

### 38.6.1.5 Status (SR)

Offset

| Register | Offset |
|----------|--------|
| SR       | 14h    |

Function

Contains data flow status.

**Diagram**

| Bits  | 31 | 30 | 29  | 28  | 27  | 26  | 25  | 24  | 23 | 22 | 21 | 20 | 19 | 18 | 17  | 16  |
|-------|----|----|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|-----|-----|
| R     |    |    |     |     | 0   |     |     | MBF |    |    |    |    | 0  |    |     |     |
| W     |    |    |     |     |     |     |     |     |    |    |    |    |    |    |     |     |
| Reset | 0  | 0  | 0   | 0   | 0   | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 0   |
| Bits  | 15 | 14 | 13  | 12  | 11  | 10  | 9   | 8   | 7  | 6  | 5  | 4  | 3  | 2  | 1   | 0   |
| R     | 0  |    | DMF | REF | TEF | TCF | FCF | WCF |    |    |    |    | 0  |    | RDF | TDF |
| W     |    |    | W1C | W1C | W1C | W1C | W1C | W1C |    |    |    |    |    |    |     |     |
| Reset | 0  | 0  | 0   | 0   | 0   | 0   | 0   | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0   | 1   |

**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-25<br>— | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 24<br>MBF  | <p>Module Busy Flag</p> <p>Indicates, in Master mode, whether there is data to transmit and LPSPI is able to transmit (for example, the HREQ pin is asserted). The HREQ pin deasserts after the PCS pin deasserts and the LPSPI master has waited for half the time specified in <a href="#">CCR[DBT]</a> with no new data to transmit.</p> <p>Slave mode sets this flag when LPSPI is enabled and PCS is asserted.</p> <p>0b - LPSPI is idle<br/>1b - LPSPI is busy</p> |
| 23-14<br>— | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 13<br>DMF  | <p>Data Match Flag</p> <p>Indicates whether the received data matches <a href="#">DMR0[MATCH0]</a> and/or <a href="#">DMR1[MATCH1]</a> (as configured by <a href="#">CFG1[MATCFG]</a>).</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p> <p>0b - No match<br/>1b - Match</p> <p>When writing</p> <p>0b - No effect<br/>1b - Clear the flag</p>                                                               |
| 12         | Receive Error Flag                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| REF       | <p>Indicates a receive FIFO overflow error. When this flag is set:</p> <ol style="list-style-type: none"> <li>1. End the transfer.</li> <li>2. Empty the receive FIFO.</li> <li>3. Clear this flag.</li> <li>4. Restart the transfer from the beginning.</li> </ol> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - No overflow</li> <li>1b - Overflow</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul> |
| 11<br>TEF | <p>Transmit Error Flag</p> <p>Indicates a transmit FIFO underrun error. When this flag is set:</p> <ol style="list-style-type: none"> <li>1. End the transfer.</li> <li>2. Clear this flag.</li> <li>3. Restart the transfer from the beginning.</li> </ol> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p> <ul style="list-style-type: none"> <li>0b - No underrun</li> <li>1b - Underrun</li> </ul> <p>When writing</p> <ul style="list-style-type: none"> <li>0b - No effect</li> <li>1b - Clear the flag</li> </ul>         |
| 10<br>TCF | <p>Transfer Complete Flag</p> <p>Indicates, in Master mode, whether all transfers are complete and LPSPI has returned to the Idle state and the transmit FIFO is empty.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p>                                                                                                                                                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                    |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | <p>0b - Not complete<br/>1b - Complete</p> <p>When writing</p> <p>0b - No effect<br/>1b - Clear the flag</p>                                                                                                                                                                                                                |
| 9<br>FCF | <p>Frame Complete Flag</p> <p>Indicates whether a frame transfer is complete after PCS deasserts.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p> <p>0b - Not complete<br/>1b - Complete</p> <p>When writing</p> <p>0b - No effect<br/>1b - Clear the flag</p> |
| 8<br>WCF | <p>Word Complete Flag</p> <p>Indicates whether the last bit of a received word is sampled.</p> <p><b>NOTE</b><br/>This field behaves differently for register reads and writes.</p> <p>When reading</p> <p>0b - Not complete<br/>1b - Complete</p> <p>When writing</p> <p>0b - No effect<br/>1b - Clear the flag</p>        |
| 7-2<br>— | Reserved                                                                                                                                                                                                                                                                                                                    |
| 1<br>RDF | <p>Receive Data Flag</p> <p>Indicates whether the number of words in the receive FIFO is greater than the value in <a href="#">FCR[RXWATER]</a>.</p> <p>0b - Receive data not ready<br/>1b - Receive data ready</p>                                                                                                         |
| 0        | Transmit Data Flag                                                                                                                                                                                                                                                                                                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                   |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TDF   | Indicates whether the number of words in the transmit FIFO is equal to or less than the value in <b>FCR[TXWATER]</b> .<br>0b - Transmit data not requested<br>1b - Transmit data requested |

### 38.6.1.6 Interrupt Enable (IER)

#### Offset

| Register | Offset |
|----------|--------|
| IER      | 18h    |

#### Function

Enables interrupts based on data flow and errors.

#### Diagram



#### Fields

| Field      | Function                                                                                        |
|------------|-------------------------------------------------------------------------------------------------|
| 31-14      | Reserved                                                                                        |
| —          |                                                                                                 |
| 13<br>DMIE | Data Match Interrupt Enable<br>Enables the data match interrupt.<br>0b - Disable<br>1b - Enable |
| 12         | Receive Error Interrupt Enable                                                                  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                      |
|------------|---------------------------------------------------------------------------------------------------------------|
| REIE       | Enables the receive complete interrupt.<br>0b - Disable<br>1b - Enable                                        |
| 11<br>TEIE | Transmit Error Interrupt Enable<br>Enables the transmit complete interrupt.<br>0b - Disable<br>1b - Enable    |
| 10<br>TCIE | Transfer Complete Interrupt Enable<br>Enables the transfer complete interrupt.<br>0b - Disable<br>1b - Enable |
| 9<br>FCIE  | Frame Complete Interrupt Enable<br>Enables the frame complete interrupt.<br>0b - Disable<br>1b - Enable       |
| 8<br>WCIE  | Word Complete Interrupt Enable<br>Enables the word complete interrupt.<br>0b - Disable<br>1b - Enable         |
| 7-2<br>—   | Reserved                                                                                                      |
| 1<br>RDIE  | Receive Data Interrupt Enable<br>Enables the receive data interrupt.<br>0b - Disable<br>1b - Enable           |
| 0<br>TDIE  | Transmit Data Interrupt Enable<br>Enables the transmit data interrupt.<br>0b - Disable<br>1b - Enable         |

### 38.6.1.7 DMA Enable (DER)

#### Offset

| Register | Offset |
|----------|--------|
| DER      | 1Ch    |

#### Function

Enables the DMA data flow.

#### Diagram



#### Fields

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-10<br>— | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 9<br>FCDE  | <p>Frame Complete DMA Enable</p> <p>Enables DMA end-of-packet processing. After the last word of a frame is read from the receive data FIFO, reading the receive data FIFO returns an end-of-packet signal with the receive data forced to FFFF_FFFFh. This continues until the DMA minor loop completes, and then SR[FCF] deasserts if the receive FIFO is empty or if LPSPI is busy (SR[MBF] = 1).</p> <p>0b - Disable<br/>1b - Enable</p> |
| 8-2<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1<br>RDDE  | <p>Receive Data DMA Enable</p> <p>Enables the receive data DMA.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                                                                                      |

Table continues on the next page...

*Table continued from the previous page...*

| Field     | Function                                                                                          |
|-----------|---------------------------------------------------------------------------------------------------|
| 0<br>TDDE | Transmit Data DMA Enable<br><br>Enables the transmit data DMA.<br><br>0b - Disable<br>1b - Enable |

### 38.6.1.8 Configuration 0 (CFGRO)

#### Offset

| Register | Offset |
|----------|--------|
| CFGRO    | 20h    |

#### Function

Includes fields to configure LPSPI.

#### Diagram



#### Fields

| Field      | Function                                                                                                                                                                                                                                                        |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-10<br>— | Reserved                                                                                                                                                                                                                                                        |
| 9<br>RDMO  | Receive Data Match Only<br><br>Enables receive data match.<br><br>When enabled, all received data that does not cause SR[DMF] to assert is discarded: <ul style="list-style-type: none"><li>Write 1 to this field when LPSPI is idle and SR[DMF] = 0.</li></ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | <ul style="list-style-type: none"> <li>After SR[DMF] = 1, this field is ignored.</li> <li>To ensure that no receive data is lost when disabling RDMO, write 0 to this field before clearing SR[DMF].</li> </ul> <p>See <a href="#">CFG1[MATCFG]</a> for the received data matching options. When disabled, all received data is stored in the receive FIFO.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                                                         |
| 8<br>CIRFIFO | <p>Circular FIFO Enable</p> <p>Enables circular FIFO.</p> <p>When enabled, the transmit FIFO read pointer is saved to a temporary register. The transmit FIFO is emptied as in normal operation, but when LPSPI is idle and the transmit FIFO is empty, the read pointer value is restored from the temporary register.</p> <p>This restoring of the read pointer causes the contents of the transmit FIFO to be cycled through repeatedly.</p> <p><b>NOTE</b></p> <p>The read pointer is restored for as long as this field is 1. Writing additional words to the FIFO when this field is 1 adds them to the end of the FIFO, up to the size of the transmit FIFO.</p> <p>0b - Disable<br/>1b - Enable</p> |
| 7-4<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 3<br>HRDIR   | <p>Host Request Direction</p> <p>Specifies the direction of the HREQ pin. You must configure the HREQ pin only as an output when LPSPI is in Slave mode. The HREQ pin direction must be an input for Master mode.</p> <p>0b - Input<br/>1b - Output</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2<br>HRSEL   | <p>Host Request Select</p> <p>Specifies the source of the host request input. When the host request function is enabled with the HREQ pin, the PCS[1] function is disabled.</p> <p>0b - HREQ pin<br/>1b - Input trigger</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1<br>HRPOL   | <p>Host Request Polarity</p> <p>Specifies the polarity of the HREQ pin or input trigger.</p> <p>0b - Active high<br/>1b - Active low</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                                                                                                                                                                     |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>HREN | <p>Host Request Enable</p> <p>Enables LPSPI, in Master mode, to start a new SPI bus transfer only if the host request input is asserted. When LPSPI is busy, the host request input is ignored.</p> <p>In Slave mode, causes the HREQ output pin to assert when data is available to be transmitted.</p> <p>0b - Disable<br/>1b - Enable</p> |

### 38.6.1.9 Configuration 1 (CFG1)

#### Offset

| Register | Offset |
|----------|--------|
| CFG1     | 24h    |

#### Function

Includes fields to configure LPSPI. You must write to this register only when LPSPI is disabled.

In addition to pin and output configurations, this register contains match configuration details; the following table shows match conditions specified in [MATCFG](#).

Table 229. Match conditions for CFG1[MATCFG]

| Condition                                                 | Description                                                                                                                                                                      |
|-----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Match first data word with compare word                   | Match if first data word equals MATCH0 logically ORed with MATCH1<br><code>first_data_word == (MATCH0    MATCH1)</code>                                                          |
| Match any data word with compare word                     | Match if any data word equals MATCH0 logically ORed with MATCH1<br><code>any_data_word == (MATCH0    MATCH1)</code>                                                              |
| Sequential match, first data word                         | Match if first data word equals MATCH0, and second data word equals MATCH1<br><code>(first_data_word == MATCH0) &amp;&amp; (second_data_word == MATCH1)</code>                   |
| Sequential match, any data word                           | Match if any data word equals MATCH0, and the next data word equals MATCH1<br><code>(any_data_word == MATCH0) &amp;&amp; (next_data_word == MATCH1)</code>                       |
| Match first data word (masked) with compare word (masked) | Match if first data word logically ANDed with MATCH1 equals MATCH0 logically ANDed with MATCH1<br><code>(first_data_word &amp;&amp; MATCH1) == (MATCH0 &amp;&amp; MATCH1)</code> |
| Match any data word (masked) with compare word (masked)   | Match if any data word logically ANDed with MATCH1 equals MATCH0 logically ANDed with MATCH1<br><code>(any_data_word &amp;&amp; MATCH1) == (MATCH0 &amp;&amp; MATCH1)</code>     |

**Diagram**

| Bits  | 31 | 30 | 29         | 28         | 27     | 26 | 25 | 24 | 23 | 22 | 21      | 20      | 19      | 18     | 17     | 16     |
|-------|----|----|------------|------------|--------|----|----|----|----|----|---------|---------|---------|--------|--------|--------|
| R     | 0  | 0  | PCSC<br>FG | OUTC<br>FG | PINCFG | 0  |    |    |    |    |         |         |         |        |        |        |
| W     |    |    |            |            |        |    |    |    |    |    |         |         |         |        |        | MATCFG |
| Reset | 0  | 0  | 0          | 0          | 0      | 0  | 0  | 0  | 0  | 0  | 0       | 0       | 0       | 0      | 0      | 0      |
| Bits  | 15 | 14 | 13         | 12         | 11     | 10 | 9  | 8  | 7  | 6  | 5       | 4       | 3       | 2      | 1      | 0      |
| R     | 0  |    | PCSPOL     |            |        |    |    |    | 0  |    | PARTIAL | NOSTALL | AUTOPCS | SAMPLE | MASTER |        |
| W     |    |    |            |            |        |    |    |    |    |    |         |         |         |        |        |        |
| Reset | 0  | 0  | 0          | 0          | 0      | 0  | 0  | 0  | 0  | 0  | 0       | 0       | 0       | 0      | 0      | 0      |

**Fields**

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-29           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| —               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 28              | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| —               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 27<br>PCSCFG    | <p>Peripheral Chip Select Configuration</p> <p>Specifies PCS pin configuration. When performing parallel transfers, you must configure this field to enable the desired transfer.</p> <p>0b - PCS[3:2] configured for chip select function</p> <p>1b - PCS[3:2] configured for half-duplex 4-bit transfers (PCS[3:2] = DATA[3:2])</p>                                                                                                                                                                                               |
| 26<br>OUTCFG    | <p>Output Configuration</p> <p>Specifies whether the output data is 3-stated between accesses (when PCS is deasserted). When performing half-duplex transfers, this field must be 1.</p> <p>0b - Retain last value</p> <p>1b - 3-stated</p>                                                                                                                                                                                                                                                                                         |
| 25-24<br>PINCFG | <p>Pin Configuration</p> <p>Specifies the pins used for input and output data during serial transfers. This field is ignored when performing parallel transfers.</p> <p>00b - SIN is used for input data; SOUT is used for output data</p> <p>01b - SIN is used for both input and output data; only half-duplex serial transfers are supported</p> <p>10b - SOUT is used for both input and output data; only half-duplex serial transfers are supported</p> <p>11b - SOUT is used for input data; SIN is used for output data</p> |
| 23-19           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 18-16<br>MATCFG | <p>Match Configuration</p> <p>Specifies the condition that causes SR[DMF] to assert. See the match conditions listed in <a href="#">Table 1</a> for more information.</p> <p><b>NOTE</b><br/>When writing to this field, either the old value or new value must be in the disabled state (0). You cannot transition from a nonzero value to another nonzero value.</p> <ul style="list-style-type: none"> <li>000b - Match is disabled</li> <li>001b - Reserved</li> <li>010b - Match first data word with compare word</li> <li>011b - Match any data word with compare word</li> <li>100b - Sequential match, first data word</li> <li>101b - Sequential match, any data word</li> <li>110b - Match first data word (masked) with compare word (masked)</li> <li>111b - Match any data word (masked) with compare word (masked)</li> </ul> |
| 15-12<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 11-8<br>PCSPOL  | <p>Peripheral Chip Select Polarity</p> <p>Specifies the polarity of each PCS pin. Bit <math>n</math> in this field (the least-significant bit is bit 0) corresponds to PCS[<math>n</math>].</p> <p><b>NOTE</b><br/>The entire PCSPOL field is not fully supported in every LPSPI module instance. See the LPSPI chip-specific information.</p> <ul style="list-style-type: none"> <li>0000b - Active low</li> <li>0001b - Active high</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                             |
| 7-5<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4<br>PARTIAL    | <p>Partial Enable</p> <p>Specifies whether LPSPI, when in Slave mode, stores a partial received word in the receive FIFO, or discards it, when PCS deasserts. See <a href="#">Partial received word</a> for more information.</p> <ul style="list-style-type: none"> <li>0b - Discard</li> <li>1b - Store</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3               | No Stall                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NOSTALL      | <p>Disables a normal operating feature that causes LPSPI, when in Master mode, to stall transfers when the transmit FIFO is empty or when the receive FIFO is full. This feature prevents transmit FIFO underruns and receive FIFO overruns. Writing 1 to this field disables this functionality.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                                           |
| 2<br>AUTOPCS | <p>Automatic PCS</p> <p>Enables automatic PCS generation. For correct operation in Slave mode, LPSPI requires the PCS signal to deassert between frames. Writing 1 to this field generates an internal PCS signal at the end of each transfer word when <a href="#">TCR[CPHA]</a> = 1.</p> <p>When this field is 1, SCK must remain idle for at least four LPSPI functional clock cycles, divided by the prescaler (see <a href="#">TCR[PRESCALE]</a>) selected between each word to ensure correct operation.</p> <p>This field is ignored in Master mode.</p> <p>0b - Disable<br/>1b - Enable</p>                                 |
| 1<br>SAMPLE  | <p>Sample Point</p> <p>Specifies the SCK clock edge on which LPSPI, when in Master mode, samples input data. Writing 1 to this field causes LPSPI to sample input data on a delayed loopback SCK clock edge, which improves the setup time when sampling data (see <a href="#">Clock loopback</a>). In this configuration, the input data setup time in Master mode is equal to the input data setup time in Slave mode.</p> <p>In Slave mode, this field is ignored.</p> <p><b>NOTE</b><br/>When SAMPLE = 1, both the input and output buffers must be enabled for the SCK pin.</p> <p>0b - SCK edge<br/>1b - Delayed SCK edge</p> |
| 0<br>MASTER  | <p>Master Mode</p> <p>Specifies the LPSPI operating mode, Master or Slave. This field directly controls the direction of the SCK and PCS pins.</p> <p>0b - Slave mode<br/>1b - Master mode</p>                                                                                                                                                                                                                                                                                                                                                                                                                                      |

### 38.6.1.10 Data Match 0 (DMR0)

Offset

| Register | Offset |
|----------|--------|
| DMR0     | 30h    |

**Function**

Specifies the match data to be used when data matching is enabled. See [CFG1\[MATCFG\]](#) for the received data matching options.

**NOTE**

Do not change the value in this register when CFG1[MATCFG] > 0.

**Diagram**

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

**Fields**

| Field  | Function                                                         |
|--------|------------------------------------------------------------------|
| 31-0   | Match 0 Value                                                    |
| MATCH0 | Specifies the MATCH0 value to be compared against received data. |

**38.6.1.11 Data Match 1 (DMR1)****Offset**

| Register | Offset |
|----------|--------|
| DMR1     | 34h    |

**Function**

Specifies the match data to be used when data matching is enabled. See [CFG1\[MATCFG\]](#) for the received data matching options.

**NOTE**

Do not change the value in this register while CFG1[MATCFG] > 0.

**Diagram**

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

**Fields**

| Field  | Function                                                         |
|--------|------------------------------------------------------------------|
| 31-0   | Match 1 Value                                                    |
| MATCH1 | Specifies the MATCH1 value to be compared against received data. |

**38.6.1.12 Clock Configuration (CCR)****Offset**

| Register | Offset |
|----------|--------|
| CCR      | 40h    |

**Function**

Contains clock configuration fields that are used only in Master mode; you can only change them when LPSPI is disabled ([CR\[MEN\]](#) = 0).

**Warning**

Writing a 32-bit value to this register overwrites [Clock Configuration 1 \(CCR1\)](#); [DBT](#) and [SCKDIV](#) always read 0.

To avoid overwriting CCR1, do one of the following:

- Write to all four fields in [Clock Configuration \(CCR\)](#) simultaneously and only once in a 32-bit data.
- Modify the values of [CCR\[SCKPCS\]](#) and/or [CCR\[PCSSCK\]](#); write only these two upper bytes in a 16-bit data or one of them in an 8-bit data.
- Modify [CCR1\[PCSPCS\]](#) and [CCR1\[SCKSCK\]](#) only or [CCR1\[SCKSET\]](#) and [CCR1\[SCKHLD\]](#) only, write respectively to [CCR\[DBT\]](#) or [CCR\[SCKDIV\]](#) in 8-bit data.

**Diagram**

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

**Fields**

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24<br>SCKPCS | SCK-to-PCS Delay<br><br>Configures SCK-to-PCS delay. In Master mode, this field helps you configure the delay from the last SCK edge to PCS negation: <ul style="list-style-type: none"><li>The delay is equal to (SCKPCS + 1) cycles of the LPSPI functional clock divided by the selected prescaler (see <a href="#">TCR[PRESCALE]</a>).</li><li>The minimum delay is one cycle.</li></ul> See <a href="#">Figure 168</a> for more information.   |
| 23-16<br>PCSSCK | PCS-to-SCK Delay<br><br>Configures PCS-to-SCK delay. In Master mode, this field helps you configure the delay from PCS assertion to the first SCK edge: <ul style="list-style-type: none"><li>The delay is equal to (PCSSCK + 1) cycles of the LPSPI functional clock divided by the selected prescaler (see <a href="#">TCR[PRESCALE]</a>).</li><li>The minimum delay is one cycle.</li></ul> See <a href="#">Figure 168</a> for more information. |
| 15-8<br>DBT     | Delay Between Transfers<br><br>Configures the delay between transfers. Writing to this field updates the contents of <a href="#">CCR1[PCSPCS]</a> and <a href="#">CCR1[SCKSCK]</a> .                                                                                                                                                                                                                                                                |
| 7-0<br>SCKDIV   | SCK Divider<br><br>Updates the contents of <a href="#">CCR1[SCKSET]</a> and <a href="#">CCR1[SCKHLD]</a> .<br>Baud rate = function clock $\div$ ( $2^{\text{PRESCALE}}$ $\times$ (SCKSET + SCKHLD + 2))                                                                                                                                                                                                                                             |

### 38.6.1.13 Clock Configuration 1 (CCR1)

#### Offset

| Register | Offset |
|----------|--------|
| CCR1     | 44h    |

#### Function

Contains clock configuration fields, which are used only in Master mode. You can change them only when LPSPI is disabled ([CR\[MEN\] = 0](#)).

#### Diagram

| Bits  | 31     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17     | 16 |
|-------|--------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------|----|
| R     | SCKSCK |    |    |    |    |    |    |    |    |    |    |    |    |    | PCSPCS |    |
| W     |        |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |
| Reset | 0      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0  |
| Bits  | 15     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1      | 0  |
| R     | SCKHLD |    |    |    |    |    |    |    |    |    |    |    |    |    | SCKSET |    |
| W     |        |    |    |    |    |    |    |    |    |    |    |    |    |    |        |    |
| Reset | 0      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0  |

#### Fields

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24<br>SCKSCK | <p>SCK Inter-Frame Delay</p> <p>Configures SCK inter-frame delay in Master mode:</p> <ul style="list-style-type: none"> <li>This field helps you configure the delay from the last SCK pulse of a frame and the first SCK pulse of the following frame, in a continuous transfer.</li> <li>The delay is equal to (SCKSCK + 1) cycles of the LPSPI functional clock divided by the selected prescaler (see <a href="#">TCR[PRESCALE]</a>).</li> <li>The minimum delay is one cycle.</li> </ul> <p><b>NOTE</b><br/>For backward compatibility, writing to <a href="#">CCR[DBT]</a> updates this field with the value written.</p> |
| 23-16<br>PCSPCS | <p>PCS to PCS Delay</p> <p>Configures PCS to PCS delay in Master mode:</p> <ul style="list-style-type: none"> <li>This field helps you configure the delay from the PCS negation to the next PCS assertion.</li> <li>The delay is equal to (PCSPCS + PCSPCS + 2) cycles of the LPSPI functional clock divided by the selected prescaler (see <a href="#">TCR[PRESCALE]</a>).</li> </ul>                                                                                                                                                                                                                                         |

Table continues on the next page...

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | <ul style="list-style-type: none"> <li>The minimum delay is two cycles.</li> <li>Half of the delay (<math>\text{PCSPCS} + 1</math>) occurs before PCS assertion and the other half of the delay (<math>\text{PCSPCS} + 1</math>) occurs after PCS negation. If the command word is updated between two transfers, then the command word is updated halfway between the PCS negation of the last transfer and PCS assertion of the next transfer.</li> <li>The command word specifies which PCS signal is used, the polarity and phase of the SCK signal, and the selected prescaler.</li> </ul> <p style="text-align: center;"><b>NOTE</b></p> <p>For backward compatibility, writing to <a href="#">CCR[DBT]</a> updates this field with (<math>\text{DBT} \div 2</math>) rounded up.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15-8<br>SCKHLD | <p>SCK Hold</p> <p>Configures the hold phase of the SCK pin in Master mode:</p> <ul style="list-style-type: none"> <li>The hold phase is the delay between the SCK edge that samples the receive data and the SCK edge that drives the transmit data.</li> <li>It is the SCK low period when <math>\text{CPHA} = 0</math> and <math>\text{CPOL} = 1</math>, or <math>\text{CPHA} = 1</math> and <math>\text{CPOL} = 0</math>. It is the SCK high period when <math>\text{CPHA} = 0</math>, <math>\text{CPOL} = 0</math> and <math>\text{CPHA} = 1</math>, <math>\text{CPOL} = 1</math>.</li> <li>The SCK hold phase delay is equal to (<math>\text{SCKHLD} + 1</math>) cycles of the LPSPI functional clock divided by the selected prescaler (see <a href="#">TCR[PRESCALE]</a>).</li> <li>The minimum delay is one cycle.</li> <li>The SCK period is equal to (<math>\text{SCKSET} + \text{SCKHLD} + 2</math>) cycles of the LPSPI functional clock divided by the selected prescaler (see <a href="#">TCR[PRESCALE]</a>).</li> <li>The SCK duty cycle is based on the difference between SCKSET and SCKHLD. You must configure both these fields to the same value for a 50/50 duty cycle.</li> </ul> <p>See <a href="#">Figure 168</a> for more information.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>For backward compatibility, writing to <a href="#">CCR[SCKDIV]</a> updates this field with (<math>\text{SCKDIV} \div 2</math>) rounded down.</p> |
| 7-0<br>SCKSET  | <p>SCK Setup</p> <p>Configures the setup phase of the SCK pin in Master mode:</p> <ul style="list-style-type: none"> <li>The setup phase is the delay between the SCK edge that drives the transmit data and the SCK edge that samples the receive data.</li> <li>It is the SCK high period when <math>\text{CPHA} = 0</math> and <math>\text{CPOL} = 1</math>, or <math>\text{CPHA} = 1</math> and <math>\text{CPOL} = 0</math>. It is the SCK low period when <math>\text{CPHA} = 0</math> and <math>\text{CPOL} = 0</math>, or <math>\text{CPHA} = 1</math> and <math>\text{CPOL} = 1</math>.</li> <li>The SCK setup phase delay is equal to (<math>\text{SCKSET} + 1</math>) cycles of the LPSPI functional clock divided by the selected prescaler (see <a href="#">TCR[PRESCALE]</a>).</li> <li>The minimum delay is one cycle.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <ul style="list-style-type: none"> <li>The SCK period is equal to (SCKSET + SCKHLD + 2) cycles of the LPSPI functional clock divided by the selected prescaler (see TCR[PRESCALE]).</li> <li>The SCK duty cycle is based on the difference between SCKSET and SCKHLD. You must configure both these fields to the same value for a 50/50 duty cycle.</li> </ul> <p>See <a href="#">Figure 168</a> for more information.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>For backward compatibility, writing to <a href="#">CCR[SCKDIV]</a> updates this field with <math>(SCKDIV \div 2)</math> rounded up.</p> |

### 38.6.1.14 FIFO Control (FCR)

#### Offset

| Register | Offset |
|----------|--------|
| FCR      | 58h    |

#### Function

Contains the receive FIFO and transmit FIFO watermark values.

#### Diagram



#### Fields

| Field | Function |
|-------|----------|
| 31-24 | Reserved |
| 23-18 | Reserved |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                          |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —                |                                                                                                                                                                                                                                   |
| 17-16<br>RXWATER | Receive FIFO Watermark<br>Causes LPSPI to set <b>SR[RDF]</b> when the number of words in the receive FIFO is greater than RXWATER. Writing a value equal to or greater than the FIFO size truncates the written value.            |
| 15-8<br>—        | Reserved                                                                                                                                                                                                                          |
| 7-2<br>—         | Reserved                                                                                                                                                                                                                          |
| 1-0<br>TXWATER   | Transmit FIFO Watermark<br>Causes LPSPI to set <b>SR[TDF]</b> when the number of words in the transmit FIFO is equal to or less than TXWATER. Writing a value equal to or greater than the FIFO size truncates the written value. |

### 38.6.1.15 FIFO Status (FSR)

#### Offset

| Register | Offset |
|----------|--------|
| FSR      | 5Ch    |

#### Function

Contains fields that indicate the number of words currently stored in the receive and transmit FIFOs.

#### Diagram

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18            | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----|----|
| R     | 0  |    |    |    |    |    |    |    |    |    | 0  |    |    | <b>RCOUNT</b> |    |    |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2             | 1  | 0  |
| R     | 0  |    |    |    |    |    |    |    |    |    | 0  |    |    | <b>TCOUNT</b> |    |    |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |               |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  |

**Fields**

| Field            | Function                                                                                    |
|------------------|---------------------------------------------------------------------------------------------|
| 31-24<br>—       | Reserved                                                                                    |
| 23-19<br>—       | Reserved                                                                                    |
| 18-16<br>RXCOUNT | Receive FIFO Count<br>Indicates the number of words currently stored in the receive FIFO.   |
| 15-8<br>—        | Reserved                                                                                    |
| 7-3<br>—         | Reserved                                                                                    |
| 2-0<br>TXCOUNT   | Transmit FIFO Count<br>Indicates the number of words currently stored in the transmit FIFO. |

**38.6.1.16 Transmit Command (TCR)****Offset**

| Register | Offset |
|----------|--------|
| TCR      | 60h    |

**Function**

Pushes the data into the transmit FIFO, in the same order as written.

When you write to either this register or to [Transmit Data \(TDR\)](#), each write pushes data into the transmit FIFO. You must write to this register only using 32-bit writes, which are tagged and cause the command register to update; after that the entry reaches the top of the FIFO and LPSPI is enabled. This allows changes to the command word and the transmit data itself to be interleaved. That is, writes to the two registers can be interleaved (write command word, then data word, then command word, and so on). Changing the command word causes all subsequent SPI bus transfers to be performed using the new command word:

- In Master mode, writing a new command word does not initiate a new transfer, unless TXMSK is 1. Transfers are initiated by transmit data in the transmit FIFO, or by a new command word (with TXMSK = 1). Hardware writes 0 to TXMSK when PCS deasserts.
- In Master mode, if the command word is changed before an existing frame has completed, then the existing frame terminates and the command word updates. The command word can be changed during a continuous transfer, if CONTC of the new command word is 1 and the command word is written on a frame size boundary.
- In Slave mode, the command word must be changed only when LPSPI is idle and there is no SPI bus transfer.

Avoid resetting the transmit FIFO after writing to this register; wait for the command register to update from the FIFO first.

Avoid register reading problems: Reading this register returns the current state of the register. Reading this register at the same time that it is loaded from the transmit FIFO can return an incorrect register value. It is recommended to:

- Read this register when the transmit FIFO is empty.
- Read this register more than once and then compare the returned values.

### Diagram

| Bits  | 31       | 30   | 29       | 28 | 27        | 26  | 25 | 24   | 23   | 22   | 21     | 20     | 19     | 18    | 17 | 16 |
|-------|----------|------|----------|----|-----------|-----|----|------|------|------|--------|--------|--------|-------|----|----|
| R     | CPOL     | CPHA | PRESCALE |    | Reserv ed | PCS |    | LSBF | BYSW | CONT | CONT C | RXMS K | TXMS K | WIDTH |    |    |
| W     |          |      |          |    |           |     |    |      |      |      |        |        |        |       |    |    |
| Reset | 0        | 0    | 0        | 0  | 0         | 0   | 0  | 0    | 0    | 0    | 0      | 0      | 0      | 0     | 0  | 0  |
| Bits  | 15       | 14   | 13       | 12 | 11        | 10  | 9  | 8    | 7    | 6    | 5      | 4      | 3      | 2     | 1  | 0  |
| R     | Reserved |      |          |    | FRAMESZ   |     |    |      |      |      |        |        |        |       |    |    |
| W     | 0        |      |          |    | 0         | 0   | 0  | 0    | 0    | 0    | 0      | 1      | 1      | 1     | 1  | 1  |
| Reset | 0        | 0    | 0        | 0  | 0         | 0   | 0  | 0    | 0    | 0    | 0      | 1      | 1      | 1     | 1  | 1  |

### Fields

| Field             | Function                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>CPOL        | <p>Clock Polarity</p> <p>Specifies the value of SCK when it is idle. You can update this field only when PCS is deasserted.</p> <p>See <a href="#">Figure 168</a> for more information.</p> <p>0b - Inactive low<br/>1b - Inactive high</p>                                                                                                                                              |
| 30<br>CPHA        | <p>Clock Phase</p> <p>Indicates whether data is captured or changed on the leading edge of SCK and captured or changed on the following edge of SCK. You can update this field only when PCS is deasserted.</p> <p>See <a href="#">Figure 168</a> for more information.</p> <p>0b - Captured<br/>1b - Changed</p>                                                                        |
| 29-27<br>PRESCALE | <p>Prescaler Value</p> <p>Specifies the division of the LPSPI functional clock. For all SPI bus transfers, this value is applied to <a href="#">Clock Configuration (CCR)</a>. You can update this field only when PCS is deasserted.</p> <p>000b - Divide by 1<br/>001b - Divide by 2<br/>010b - Divide by 4<br/>011b - Divide by 8<br/>100b - Divide by 16<br/>101b - Divide by 32</p> |

Table continues on the next page...

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | 110b - Divide by 64<br>111b - Divide by 128                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 26<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 25-24<br>PCS | <b>Peripheral Chip Select</b><br>Configures the peripheral chip select used for the transfer. This field is updated only when PCS is deasserted.<br><br><b>NOTE</b><br>This entire field is not fully supported in every LPSPI module instance. See the chip-specific LPSPI information.<br><br>00b - Transfer using PCS[0]<br>01b - Transfer using PCS[1]<br>10b - Transfer using PCS[2]<br>11b - Transfer using PCS[3]                                                                        |
| 23<br>LSBF   | <b>LSB First</b><br>Indicates whether data is transferred with MSB first or LSB first.<br>0b - MSB first<br>1b - LSB first                                                                                                                                                                                                                                                                                                                                                                      |
| 22<br>BYSW   | <b>Byte Swap</b><br>Swaps the contents of [31:24] with [7:0] and [23:16] with [15:8] for each transmit data word read from the FIFO and for each received data word stored to the FIFO (or compared with match registers).<br>0b - Disable byte swap<br>1b - Enable byte swap                                                                                                                                                                                                                   |
| 21<br>CONT   | <b>Continuous Transfer</b><br>Enables continuous transfer:<br><ul style="list-style-type: none"> <li>• In Master mode, this field keeps PCS asserted at the end of the frame size until a command word is received that starts a new frame.</li> <li>• In Slave mode, when this field is enabled, LPSPI only transmits the first FRAMESZ bits, after which LPSPI transmits received data (assuming a 32-bit shift register) until the next PCS negation.</li> </ul> 0b - Disable<br>1b - Enable |
| 20<br>CONTC  | <b>Continuing Command</b><br>Enables the command word to be changed within a continuous transfer in Master mode:                                                                                                                                                                                                                                                                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | <ul style="list-style-type: none"> <li>The initial command word must enable continuous transfer (CONT = 1).</li> <li>The continuing command must have CONTC = 1.</li> <li>The continuing command word must be loaded on a frame size boundary.</li> </ul> <p>For example, if the continuous transfer has a frame size of 64 bits, then a continuing command word must be loaded on a 64-bit boundary.</p> <p>In Slave mode, this field modifies the internal <a href="#">RXMSK</a> and <a href="#">TXMSK</a> configuration after the first FRAMESZ bits and until PCS negation:</p> <ul style="list-style-type: none"> <li>Receive data is discarded after the first FRAMESZ bits. If <a href="#">CONT</a> is also 1, this does not block the transmission of received data.</li> <li>Transmit data is not masked after the first FRAMESZ bits. This allows the first FRAMESZ bits to be received and a response transmitted.</li> </ul> <p>0b - Command word for start of new transfer<br/>1b - Command word for continuing transfer</p> |
| 19<br>RXMSK     | <p>Receive Data Mask</p> <p>Masks receive data (receive data is not stored in the receive FIFO).</p> <p>0b - Normal transfer<br/>1b - Mask receive data</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 18<br>TXMSK     | <p>Transmit Data Mask</p> <p>Masks transmit data (no data is loaded from the transmit FIFO and the output pin is 3-stated). In Master mode, TXMSK initiates a new transfer that cannot be aborted by another command word. TXMSK automatically transitions to 0 at the end of the transfer.</p> <p>0b - Normal transfer<br/>1b - Mask transmit data</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 17-16<br>WIDTH  | <p>Transfer Width</p> <p>Configures serial (1-bit) or parallel transfers. For half-duplex parallel transfers, either <a href="#">RXMSK</a> or <a href="#">TXMSK</a> must be 1.</p> <p>00b - 1-bit transfer<br/>01b - 2-bit transfer<br/>10b - 4-bit transfer<br/>11b - Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15-12<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 11-0<br>FRAMESZ | <p>Frame Size</p> <p>Configures the frame size in number of bits equal to (FRAMESZ + 1):</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <ul style="list-style-type: none"> <li>The minimum frame size is 8 bits.</li> <li>If the frame size is larger than 32 bits, then the frame is divided into multiple words of 32 bits; each word is loaded from the transmit FIFO and stored in the receive FIFO separately.</li> <li>If the size of the frame is not divisible by 32, then the last load of the transmit FIFO and store of the receive FIFO contains the remainder bits. For example, a 72-bit transfer consists of three words: the first and second words are 32 bits, and the third word is 8 bits.</li> </ul> |

### 38.6.1.17 Transmit Data (TDR)

#### Offset

| Register | Offset |
|----------|--------|
| TDR      | 64h    |

#### Function

Pushes the data into the transmit FIFO, in the same order that the data is written. You can write to this register using 32-, 16-, or 8-bit writes.

When you write to this register or to [Transmit Command \(TCR\)](#), each write pushes data into the FIFO with zero pushed in unwritten bytes.

#### Diagram



#### Fields

| Field | Function                                                                                                                                                                                                                                                                                                            |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0  | Transmit Data                                                                                                                                                                                                                                                                                                       |
| DATA  | Indicates transmit data. Both 8-bit and 16-bit writes of transmit data zero-extend the data written and push the data into the transmit FIFO. To zero-extend 8-bit and 16-bit writes (to 32 bits) means that the higher order (most significant) empty parts of the 8-bit and 16-bit writes are filled with zeroes. |

### 38.6.1.18 Receive Status (RSR)

#### Offset

| Register | Offset |
|----------|--------|
| RSR      | 70h    |

#### Function

Contains data flow status fields for receive FIFO.

#### Diagram



#### Fields

| Field        | Function                                                                                                                                           |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2<br>—    | Reserved                                                                                                                                           |
| 1<br>RXEMPTY | RX FIFO Empty<br>Indicates whether the receive FIFO is empty.<br>0b - Not empty<br>1b - Empty                                                      |
| 0<br>SOF     | Start of Frame<br>Indicates whether this is the first data word received after PCS assertion.<br>0b - Subsequent data word<br>1b - First data word |

### 38.6.1.19 Receive Data (RDR)

#### Offset

| Register | Offset |
|----------|--------|
| RDR      | 74h    |

#### Function

Pulls the first entry from the receive FIFO.

#### Diagram



#### Fields

| Field | Function     |
|-------|--------------|
| 31-0  | Receive Data |
| DATA  |              |

### 38.6.1.20 Receive Data Read Only (RDROR)

#### Offset

| Register | Offset |
|----------|--------|
| RDROR    | 78h    |

#### Function

Returns the first entry in the receive FIFO but does not remove the data from the FIFO.

**Diagram**

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

**Fields**

| Field | Function     |
|-------|--------------|
| 31-0  | Receive Data |
| DATA  |              |

**38.6.1.21 Transmit Command Burst (TCBR)****Offset**

| Register | Offset |
|----------|--------|
| TCBR     | 3FCh   |

**Function**

Supports burst transfers of command data to the transmit FIFO for use with the DMA controller.

**Diagram**

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

## Fields

| Field | Function                                                |
|-------|---------------------------------------------------------|
| 31-0  | Command Data                                            |
| DATA  | Writes data to <a href="#">Transmit Command (TCR)</a> . |

### 38.6.1.22 Transmit Data Burst (TDBR0 - TDBR127)

#### Offset

For n = 0 to 127:

| Register | Offset          |
|----------|-----------------|
| TDBRn    | 400h + (n × 4h) |

#### Function

Supports burst transfers of data to the transmit FIFO for use with the DMA controller. The size of this register is 512 bytes.

#### Diagram



#### Fields

| Field | Function                                             |
|-------|------------------------------------------------------|
| 31-0  | Data                                                 |
| DATA  | Writes data to <a href="#">Transmit Data (TDR)</a> . |

### 38.6.1.23 Receive Data Burst (RDBR0 - RDBR127)

#### Offset

For n = 0 to 127:

| Register | Offset          |
|----------|-----------------|
| RDBRn    | 600h + (n × 4h) |

**Function**

Supports burst transfers of data from the receive FIFO. The size of this register is 512 bytes.

**Diagram****Fields**

| Field | Function                                             |
|-------|------------------------------------------------------|
| 31-0  | Data                                                 |
| DATA  | Reads data from <a href="#">Receive Data (RDR)</a> . |

# Chapter 39

## Improved Inter-Integrated Circuit (I3C)

### 39.1 Chip-specific MIPI I3C information

Table 230. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | I3C            | <a href="#">I3C</a>                 |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 39.1.1 Module instances

This device has one instances of the MIPI I3C module: I3C0.

### 39.2 Overview

I3C is a communications processor that improves upon the use and power of I2C, and provides an alternative to SPI for mid-speed applications.

The I3C bus protocol supports:

- In-band interrupts (IBI). These interrupts go from target to controller without extra wires, and the controller knows which target sent the interrupt.
- Common Command Codes (CCC)
- Dynamic addressing
- Multi-controller/multi-drop
- Hot-Join (HJ)
- I2C compatibility

I3C supports all required and most optional features of the MIPI Alliance Specification for I3C, v1.0 and v1.1, except for ternary data rates (HDR-TSP and HDR-TSL). See [Features](#).

### 39.2.1 Block diagram



Figure 170. Block diagram

### 39.2.2 Features

- Two-wire multidrop bus capable of 12.5 MHz clock speeds, with up to 11 devices.
  - Uses standard pads with 4 mA drive.
  - Dynamically assigns target addresses, and targets do not require static addresses. However, targets can have an I2C static address assigned at startup, so the target can operate on an I2C bus. By default, I3C supports seven-bit I2C-style addresses.
  - Allows targets to use the inbound SCL clock as the peripheral clock (instead of the clock from the controller) so devices can have slow or inaccurate clocks internally.
  - Allows simple targets, such as temperature sensors, to have no internal clock.
  - I3C controller supports handoff from Open-Drain to Push-Pull mode for ACK to data transfer.
  - Normally the controller terminates the read, but for I3C, the target can also end the read.
- In-Band Interrupts (IBI) allow targets to send notifications to a controller.
  - Can be equivalent to a separate GPIO, but can also be directly data-bearing.
  - Can be prioritized. When multiple targets send interrupts to a controller at the same time, the order is resolved. Dynamic addresses establish the priority of the targets, so the controller controls the priority of the targets. Targets with lower-value dynamic addresses are higher priority level IBIs.
  - Can start interrupts even when the controller is not active on the bus. No need for a free-running clock, but starting an interrupt requires a Bus Available condition.

- Can resolve an initial event via a time-stamping option, not requiring an interrupt.
- Built-in commands for applications created in software or firmware by using the register interface kept in a separate space. These commands do not collide with normal controller-to-target messages.
  - Controls bus behavior, modes and states, low-power state, inquiries, and more.
  - Has extra room for new built-in commands for other groups.
- Organized forms of multicontroller modes:
  - Secondary controllers, which use clean handoffs between different controllers.
- Hot-join onto I3C bus allows devices to connect to the bus later than when the bus starts.
  - Enables a device or module to access the I3C bus after power up or when physically inserted onto the I3C bus.
  - Provides a clean method for notification when new devices or modules access the I3C bus.
- Can use both I2C and I3C buses.
  - I3C supports specific legacy I2C devices on the bus.
  - I3C target devices can operate on I2C buses.
  - Supports bridging to I2C, SPI, UART, and other buses.
  - Special mode for old-style I2C buses (no targets) with clock stretching.
- Higher data rate modes are available.
  - Has a High Data Rate - Double Data Rate (HDR-DDR) mode, which is double the data rate of SDR
  - Only the controller and the specific target must support the higher data rate. The other targets can ignore it.

I3C supports most of the I3C features (as given in [Target Capabilities \(SCAPABILITIES\)](#) and [Target Capabilities 2 \(SCAPABILITIES2\)](#), except for the ternary data rates (HDR-TSP and HDR-TSL) and peer-to-peer messaging, which it does not support.

## 39.3 Functional description

### 39.3.1 Operating modes

This section describes all functional operation modes of the I3C module.

#### 39.3.1.1 Target and controller roles for I3C

The I3C protocol defines these roles for devices on the I3C bus:

- Main Controller. Initially configures the I3C bus and serves as the first active controller.
- Secondary Controller. Accepts the controller role from any active controller, to become the new active controller. And may then pass the controller role along: either back to the previous active controller, or on to any other controller-capable device.
- Target. Responds to commands from any I3C controller.
- I2C target. Responds to commands from any controller.

The I3C peripheral contains both controller and target components and can be configured to be either controller or target, or as target with secondary controller capability. However, if the I3C is chosen to be a controller, then the I3C peripheral supports Target mode to facilitate handoffs to multiple controllers.

In general, any I3C controller can be a controller or a target, because a controller becomes a target when giving over control to another controller. The only exceptions to this rule occur when using point-to-point communication or when using a controller that never shares controllership.

### 39.3.1.1.1 Controller requirements

Controller mode uses software that supports the requirements of the controller (including as a secondary controller):

- Managing the Enter Dynamic Address Assignment (ENTDAA) assigning dynamic addresses to each target. This process is supported by the I3C peripheral but requires the software to make choices.
- Driving the serial data (SDA) signal in both Open-Drain and Push-Pull mode. After Start, SDA is in Open-Drain mode and after Repeated Start it is in Push-Pull mode.
  - SDA is subject to arbitration, because both controller and target can drive the SDA line. Arbitration is also useful for handoff from controller to target.
  - The ninth bit of SDA controller write data is an odd parity bit.
- Building a table of targets and their capabilities to control which actions and commands may be sent to the targets.
- Managing requests such as IBI and controller request (handoff).
- Adjusting clock speed or write-to-read timing to match the limitations of the target. This adjustment can be done in hardware using dividers and uneven duty cycles, but the software must decide.
- Adjusting the maximum data length.
- Being a target after the controller role handoff to another controller-capable device.

The controller needs an accurate clock capable of running at a frequency that is a multiple of a frequency between 11 MHz and 12.5 MHz. For example:

Possible clock frequencies:

- 24 MHz (multiple of 12 MHz)

If required to use a lower I3C SCL value, for example as small as 5 MHz (Although the lower value would not support a mixed bus system):

- Then the controller clock can be a multiplier of that value.
- A lower SCL can also be achieved using a higher PPBAUD value.

### 39.3.1.1.2 I3C target acts like I2C target on I3C buses

If the target is assigned an I2C static address, the I3C target acts like an I2C device when it first turns on. If the I3C target is placed on an I2C bus with an I2C controller, then the I3C target stays in I2C mode and operates normally. The software is aware that the I3C target is in I2C mode, because:

- There has not been a [SSTATUS\[DACHG\]](#) interrupt indicating that a dynamic address was assigned.

For full I2C support of Fast mode (Fm) and Fast-mode Plus (Fm+), the pads must support a 50-ns spike filter. This filter must be turned off when the I3C 7Eh broadcast address is received (indicating an I3C controller). You can turn off the spike filters via hardware using the raw net indicating that the address was received or via software. A 50-ns spike filter is not needed for the I3C to operate on an I2C bus. Therefore, the spike filter is not a requirement for the I3C peripheral.

Depending on the configuration, the block supports most I2C features. Supported features include extended 10-bit address, DeviceID, and software reset. See details in [Target Capabilities \(SCAPABILITIES\)](#) and [Target Capabilities 2 \(SCAPABILITIES2\)](#) registers.

### 39.3.1.1.3 How a target rejoins the I3C bus

When a target tries to rejoin the I3C bus following a power-up or hard reset, the target needs a new Dynamic Address (DA). The target can rejoin the I3C bus in these ways:

- If the dynamic address is lost, Hot-Join is used.
- If the dynamic address is retained in the peripheral (for example, with state retention flip-flops), [SCONFIG\[OFFLINE\]](#) is used (see below).

When **SCONFIG[SLVENA]** is 1, **SCONFIG[OFFLINE]** may become 1. This setting causes the peripheral to rejoin the bus safely. It does so by ensuring that the I3C bus is not in HDR mode, using the same approach as TE0 or TE1 exit. The peripheral waits for the HDR Exit Pattern, or for 60 µs of SCL and SDA lines not changing, whichever occurs first.

After using **SCONFIG[OFFLINE]**, the I3C peripheral cannot safely use IBI until **SSTATUS[STOP]** is 1. This status ensures that the next START is safe to use for IBI.

If the application must perform an IBI, it should wait for **SSTATUS[STOP]** to become 1, or for SCL and SDA lines to remain high for 200 µs. This process can be done using the **SSTATUS** and **SINTSET** controls.

- If **SSTATUS** indicates that the bus is not busy and the peripheral interrupts on START or STOP, use a timer to measure 200 µs. If the timer finishes with no START or STOP, it is safe to use IBI.
- If a START causes an interrupt, then the timer should be turned off and the application should wait for a STOP.
- If a STOP causes an interrupt, it is safe to use IBI.

### 39.3.1.2 Using the I3C controller for I2C and I3C

The I3C controller operates with this set of built-in capabilities with the application flow:

- Built-in Enter Dynamic Address Assignment (ENTDAA) mechanism to simplify the assignment of dynamic addresses to targets. This feature is used when Set Dynamic Address from Static Address (SETDASA) is not available.

#### NOTE

When SETDASA CCC is available, use the SETDASA CCC before using the ENTDAA CCC; all targets without assigned dynamic addresses respond to the ENTDAA CCC.

- Request for START + Address with IBI support, including both I2C and I3C modes.
- SDR Write flow via FIFO, with automatic parity in I3C and ACK or NACK detection in I2C.
- SDR Read flow via the FIFO, with an automatic NACK generator for I2C, and optional use of a terminate generator for I3C.
- Request for repeated START + Address or STOP when finished with previous, including both I2C and I3C.
- Auto-IBI mode, which responds immediately to a target-initiated IBI and can be used when in sleep or deep sleep.
- Special message mode for SDR and DDR to simplify for DMA use.
- Automated SCL, SDA, pullup, and High-Keeper controls.
- I2C and I3C frequency and duty cycle configurations from functional clock.

#### NOTE

The [Controller Configuration \(MCONFIG\)](#) and [Controller In-band Interrupt Registry and Rules \(MIBIRULES\)](#) registers must be configured before using the controller.

### 39.3.1.3 Protocol modes and states

The following modes are activated in I3C:

- I2C mode is the default mode on startup.
  - If no I2C Static Address is used, this default has no effect other than to track frames looking for I3C transitional frames.
  - If an I2C Static Address is used, the device can interact with the I2C bus controller using the address.
- While in I2C mode, I3C Transitory Frame mode occurs whenever the I3C broadcast address is received (7Eh). In particular:
  - This mode occurs when 7Eh is broadcast followed by a SETDASA from the controller. If there is a Static Address match or 01h, the target is assigned a Dynamic Address and it enters I3C SDR mode.

- This mode occurs when 7Eh is broadcast followed by an ENTDAA from the controller. If the target can send a 48-bit provisioned ID (48b ID), a Dynamic Address is assigned, and the target enters I3C SDR mode.
- If a Hot-Join arbitrated event occurs (sending 02h when the controller generates another address such as 7Eh), there is a conceptual Hot-Join mode. ENTDAA or SETDASA sets a Dynamic Address to resolve the event, and the target enters I3C SDR mode.

**NOTE**

An I3C target can operate as a normal I2C target only when it has a Static Address. Otherwise, it matches nothing in I2C and waits for the above events.

- I3C SDR mode is the standard mode once I3C activates, which is defined by a Dynamic Address being assigned. This mode is the resting mode of I3C, and all devices are normally in SDR mode.
  - RSTDAA CCC causes an exit from SDR mode and a return to I2C mode. This transition is not normally used.  
RSTDAA can be issued to ensure all I3C targets participate in an upcoming dynamic address assignment process, before the I3C controller starts assigning the target address.
  - SETNEWDA does not affect the SDR mode, it only changes the Dynamic Address of an I3C device that already had a Dynamic Address assigned.
  - When in SDR mode, the device ignores messages to or from its original I2C Static Address.
- I3C CCC Command submode of type Direct or Broadcast.
  - Exit the Broadcast CCC submode by a repeated START or by a STOP.
  - Exit the Direct CCC submode by a 7Eh broadcast address after a repeated START or by a STOP.
  - I3C Dynamic Address Assignment (DAA) CCC command enters DAA mode. This mode is a special mode for dynamic addressing. Use STOP to exit. If a target has a Dynamic Address, the command is ignored.
- I3C SETDASA CCC command enters the Static Address Match submode. This mode allows matching the Static Address of the device (if any).
  - The command is ignored when a target has a Dynamic Address, or when the target in I2C mode has no Static Address.

**NOTE**

The special point-to-point address is also matched.

- I3C HDR modes are activated by ENTHDRn CCC commands, where n represents the type of HDR (0 to 7). This mode is valid until an HDR Exit Pattern, whether HDR mode for a target is supported or not.
  - DDR included
  - Exit-pattern detection must always be on to prevent errors. Alternatively, it could be set to only activate on ENTHDR.
- I3C HDR-BT modes are also activated by ENTHDRn CCC commands and exited by HDR Exit Pattern.
- Machine learning (ML) data transfer is available for data transfers between ML-capable I3C Devices that have ML functionality enabled.
- A special HDR-DDR syntax is used for transmitting CCC in the HDR-DDR protocol.
- Optionally, multiple I3C target devices can share a single group address. This sharing allows a controller device to send an I3C message to all target devices in a group simultaneously rather than one at a time. Only for targets that support the Group Address capability.
- Internal states such as IBI/no-IBI and low-power mode, are flagged internally. See [SSTATUS\[EVDET\]](#). These states are exported to the application and affect the engine to prohibit it from performing a prohibited operation.

### 39.3.1.4 Address match

For an address match to occur, the target matches the I3C broadcast address and either the I2C-style Static Address or the I3C Dynamic Address.

- I3C broadcast address, 111 1110b (written as 7Eh in spec)
- I2C-style Static Address, but only if:
  - The device has a Static Address.
  - Not in I3C mode. Only matches until the ENTDAA, SETDASA, or the SETAASA command has assigned a Dynamic Address.

#### NOTE

SETDASA matches the Static Address or the special one-controller-to-one-target point-to-point address.

- I3C Dynamic Address once assigned by ENTDAA or SETDASA or modified by SETNEWDA.

The address match is inactive (just listening) for all repeated START commands and also for START, unless an IBI, CR, or Hot-Join has been activated. If inactive, it simply tries to match. If not matched, it waits for a repeated START or a STOP. If an IBI, CR, or Hot-Join has been activated, the arbitration mechanism is used for START (but never for a repeated START).

If matching the 7Eh broadcast address, it listens for a CCC until the next repeated START or a STOP.

## 39.3.2 Operations

This section describes the operations of the module.

### 39.3.2.1 Reading and writing I2C messages using the normal method

#### NOTE

I2C Fm and I2C Fm+ modes are supported for legacy I2C devices as per the I3C standard specifications. See [I2C configuration for meeting timing requirement for Fm and Fm+ modes](#).

The normal method is as follows.

1. Set up interrupts.
  - MCTRLDONE: Indicates when the module completes an MCTRL request.
  - COMPLETE: Indicates when data has finished sending or being received.
  - RXPEND: For read operations. Used with the [Controller Data Control \(MDATACTRL\)](#) register to set the FIFO trigger. Can also be used to allow DMA to read out data.
  - TXNOTFULL: For write operations. Used with the [MDATACTRL](#) register to set the FIFO trigger. Can also be used to allow DMA to supply data.
  - IBIWON: Indicates that an IBI, CR, or HJ has won the arbitration on a header address.
  - MERRWARN: Indicates causes of errors and warnings.
2. Configure these fields in the [Controller Control \(MCTRL\)](#) register simultaneously.
  - a. Write 1 to [MCTRL\[REQUEST\]](#) (EmitStartAddr).
  - b. Write 1 to [MCTRL\[TYPE\]](#) (I2C).
  - c. Set [MCTRL\[IBIRESP\]](#) to respond to IBIs in your chosen manner.
  - d. Write 1 to [MCTRL\[DIR\]](#) for read, or write 0 for write.
  - e. Write the static address of the I2C target to [MCTRL\[ADDR\]](#).

- f. For read operations, set [MCTRL\[RDTTERM\]](#) to the maximum length to auto-terminate, or set it to stop as the data is read out. For example, set it to 1 (with REQUEST = 0) to stop after the next character.
3. Write or read the data.
- For write operations, write the [Controller Write Data Byte \(MWDATAB\)](#) register for each byte before the last byte, then write the [Controller Write Data Byte End \(MWDATABASE\)](#) register for the last byte.
    - This operation can be done or started before setting up interrupts.
    - If there is more data than the FIFO can hold, use the TXNOTFULL interrupt based on the trigger level. This interrupt allows the application to provide more data or to use DMA.
  - For read operations, wait for RXPEND, and then read out data via the [Controller Read Data Byte \(MRDATAB\)](#) register. DMA may also be used.
4. On COMPLETE, the message may be ended with a STOP, or a new message started with a repeated START.
- a. Write 2 to [MCTRL\[REQUEST\]](#) (EmitStop to STOP). Then wait for MCTRLDONE status to be asserted for its completion. (While sending STOP in I2C mode MCONFIG[ODSTOP] should be 1 and MCTRL[TYPE] should be 1.)
  - b. Write 1 to [MCTRL\[REQUEST\]](#) (EmitStartAddr to restart). IBI is not possible in this case.

### 39.3.2.2 Reading and writing I3C messages using the normal methods (SDR and HDR-DDR)

The normal method for I3C is the same as the method for I2C with a few differences.

1. Set up interrupts:
  - MCTRLDONE: Indicates when the I3C module completes an MCTRL request.
  - COMPLETE: Indicates when data has finished sending or being received.
  - RXPEND: For read operations. Used with the [Controller Data Control \(MDATACTRL\)](#) register to set the FIFO trigger. Can also be used to allow DMA to read out bytes.
  - TXNOTFULL: For write operations. Used with the [Controller Data Control \(MDATACTRL\)](#) register to set the FIFO trigger. Can also be used to allow DMA to supply bytes.
  - IBIWON: Indicates that an IBI, CR, or HJ has won the arbitration on a header address.
  - MERRWARN: Indicates causes of errors and warnings for software to check.
2. Set up the [Controller Control \(MCTRL\)](#) register.
  - **Option 1:** Configure the MCTRL register fields simultaneously in this way:
    - a. Write 1 to [MCTRL\[REQUEST\]](#) (EmitStartAddr).
    - b. Write 0 to [MCTRL\[TYPE\]](#) (for I3C SDR mode) or write 2 (for DDR mode)
    - c. Set [MCTRL\[IBIRESP\]](#) to respond to IBIs in your chosen manner.
    - d. Write 1 to [MCTRL\[DIR\]](#) for read, or write 0 for write.
    - e. Write the dynamic address of the I3C target to [MCTRL\[ADDR\]](#).
    - f. For read operations, you can set [MCTRL\[RDTTERM\]](#) to the maximum length to auto-terminate.
    - g. For write operations, pre-writing the data (MWDATAB or MWDATAH) is preferred to ensure that there are no time delays waiting on the data.

For DMA with MCTRL, use [Controller Write Byte Data 1\(to bus\) \(MWDATAB1\)](#) or [Controller Write Halfword Data \(to bus\) \(MWDATAH1\)](#) registers.

**NOTE**

HDR-DDR mode requires writing an 8-bit command value for read or write. This value must be written into the TX FIFO via [Controller Write Data Byte \(MWDTAB\)](#). The END bit is not used for this byte.

- **Option 2:** This option is preferred when stopped (bus free condition) in SDR mode, and not in HDR-DDR mode. It allows any target to issue an IBI, and it avoids collisions with an IBI address. Also, it is faster (when the MSB of the Dynamic Address is always 0).

Configure the MCTRL register in this way:

- a. Write 1 to [MCTRL\[REQUEST\]](#) (EmitStartAddr). No pre-written transmit data can be in the FIFO.
- b. Write 0 to [MCTRL\[TYPE\]](#) (I3C).
- c. Set [MCTRL\[IBIRESP\]](#) to respond to IBIs in your chosen manner.
- d. Write 0 to [MCTRL\[DIR\]](#).
- e. Write 7Eh to [MCTRL\[ADDR\]](#).
- f. Wait for MCTRLDONE (via interrupt, for example), then proceed as in Option 1. The Option 2 method has advantages for IBIs when 7Eh is sent on START (but not on repeated STARTs).

### 3. Write or read the data.

- For write operations, write the [MWDTAB](#) register for each byte before the last byte, then write the [Controller Write Data Byte End \(MWDTABE\)](#) register for the last byte. For HDR-DDR, the byte with END must be even (second, fourth, sixth, and so on) because DDR uses byte pairs.
  - This operation can be done or started before step 1 (REQUEST = 1) of the Option 1 method, but not before the Option 2 method.
  - If there is more data than the FIFO can hold, use the TXNOTFULL interrupt based on the trigger level. This interrupt allows the application to provide more data or to use DMA.
- For read operations, wait for RXPEND, and then read out data via the [Controller Read Data Byte \(MRDTAB\)](#) or [Controller Read Data Halfword \(MRDTAH\)](#) register. DMA may also be used. If using DMA, read using same registers.

### 4. On COMPLETE, the message may be ended with STOP (or EXIT in HDR mode). Alternatively, a new message may be started with a repeated START (or HDR-Restart in HDR mode).

- In SDR mode, write 2 to [MCTRL\[REQUEST\]](#) (EmitStart to STOP). Then wait for MCTRLDONE status to be asserted for its completion.
- For HDR mode, write 6 to [MCTRL\[REQUEST\]](#) (ForceExit) to end HDR mode. Then wait for MCTRLDONE status to be asserted for its completion. When sending the HDR exit pattern, [MCONFIG\[ODSTOP\]](#) must be 0.
- Write 1 to [MCTRL\[REQUEST\]](#) (EmitStartAddr to start another message). IBI is not possible in this case.

#### 39.3.2.3 Determining bus types with EmitStartAddr

Table 231. Determining bus types with EmitStartAddr

| Value | Meaning when REQUEST = 1 (EmitStartAddr)                                                                                       | Meaning when REQUEST = 2 (EmitStop) | Meaning when REQUEST = 6 (ForceExit) |
|-------|--------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|--------------------------------------|
| 0     | I3C - SDR mode of I3C                                                                                                          | I3C - SDR mode of I3C               | Exit Pattern                         |
| 1     | I2C - Standard I2C protocol                                                                                                    | I2C - Standard I2C protocol         | Reserved                             |
| 2     | DDR - HDR-DDR mode of I3C. Enter DDR mode (7E and then ENTHDR0), if the module is not in DDR mode. The 1st byte written to the | Reserved                            | Target Reset                         |

*Table continues on the next page...*

Table 231. Determining bus types with EmitStartAddr (continued)

| Value | Meaning when REQUEST = 1 (EmitStartAddr)                                                                                                                                                     | Meaning when REQUEST = 2 (EmitStop) | Meaning when REQUEST = 6 (ForceExit) |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|--------------------------------------|
|       | Tx FIFO must be a command and already in the FIFO. To end DDR mode, use ForceExit.                                                                                                           |                                     |                                      |
| 3     | BT - HDR-BT mode of I3C. If not already in HDR-BT, will automatically Enter BT (send 7E and ENTHDR3). When using this, you must also set the MHDRBTCFG register for multilane and CMD rules. | Reserved                            | Reserved                             |

| Value | Meaning - DAA processing TYPE (rules) when REQUEST = 4 (ProcessDAA)            |
|-------|--------------------------------------------------------------------------------|
| 0     | DA comes from MWDATAB[VALUE], if not 1st time, continues to next 7E/R request. |
| 1     | Reserved                                                                       |
| 2     | DA comes from MWDATAB[VALUE], if not 1st time, STOPs after assignment.         |
| 3     | Reserved                                                                       |

For more information, see [MCTRL\[TYPE\]](#).

### 39.3.2.4 Sending a CCC to I3C targets

The normal Common Command Code (CCC) method is to use an I3C write operation with an address of 7Eh. The first byte is the CCC.

- For Broadcast type, any remaining bytes are sent with the CCC. This operation ends with a STOP or a repeated START and 7Eh.
- For Direct type, only the CCC byte is sent (or by a CCC and a defining byte, if required by the CCC).

These bytes are followed by a repeated START and the address of the I3C target (for SETDASA, this address is its I2C Static address). This sequence may be repeated with more repeated STARTs and addresses until done. It may end in STOP or a repeated START and 7Eh. After the repeated start and target address, the values are read or written depending on the CCC.

- I3C provides interrupts (by hardware) for Unhandled and Handled CCC when received by the target. Its state is reflected in the [Target Status \(SSTATUS\)](#) register.

The I3C spec requires I3C controllers to emit a single START, 7E/W sequence with both SCL High and SCL Low half periods at full open-drain timing (for example, 200 ns). This sequence allows I3C targets acting as I2C legacy devices to turn off their I2C 50-ns spike filters, if they have them.

#### NOTE

START, 7E/W is notation indicating a START command, followed by the 7Eh broadcast address, followed by a write command.

After that sequence, addresses following START may be sent with Open-Drain Low (for example, 200 ns) but High of Push-Pull timing (for example, 40 ns). The I3C controller should emit this START, 7E/W sequence with MCONFIG[ODHPP] = 0. ODHPP is Open-Drain High period at Push-Pull speeds, and MCONFIG[ODHPP] is usually 1.

#### NOTE

MCONFIG[ODHPP] is ignored when sending a message to an I2C legacy device on an I3C bus.

**NOTE**

Each repeated START is a new EmitStart request. This request can be chained by interrupt or pushed by message model using DMA.

### 39.3.2.5 In-Band Interrupt (IBI) handling

An IBI occurs when a target sends its address after a START, and that address is numerically the lowest. That is, it is lower than the address sent by the controller and addresses sent by any other targets. When the controller sends 7Eh, the controller always loses the arbitration, by design.

The IBI can occur unexpectedly when any new START (not a repeated START) is sent. The IBI can also occur in response to a target pulling SDA low. This condition can occur in one of two ways:

- The controller has set the request to AutoIBI mode, so the IBI occurs automatically. The controller sends 7Eh to allow the target to win the arbitration.
- The application receives the SLVSTART (target START request) interrupt, so it sends 7Eh.

The IBI response is configured by [MCTRL\[IBIRESP\]](#), which can be set to:

- NACK. Always reject the IBI.
- ACK. Always accept the IBI.
  - The [Controller In-band Interrupt Registry and Rules \(MIBIRULES\)](#) register must be configured so that the engine knows whether bytes follow.
  - If IBI bytes follow (also known as IBI Mandatory byte), then the COMPLETE field does not become 1 when IBIWON becomes 1. RXPEND becomes 1 for one or more bytes in the Receive FIFO. When the last byte is received, then COMPLETE becomes 1. The controller automatically stops IBI data after nine total bytes (including Mandatory Data byte). [MCTRL\[RDTTERM\]](#) can be used with [MCTRL\[REQUEST\]](#) = 0 to end sooner. I3C supports address ACK to Mandatory Byte transition during IBI from Open\_Drain (controller ACKs the target address) to Push Pull (target sends SDR data).
  - I3C target supports up to seven bytes (maximum limit is [IBIEXT1\[MAX\]](#)) of Extended IBI Data following a Mandatory Data byte. Extended Data to send, if any, is present in the [Extended IBI Data 1 \(IBIEXT1\)](#) and [Extended IBI Data 2 \(IBIEXT2\)](#) registers.
- Manual. Allow the decision to be made by the application on a case-by-case basis.
  - The application rewrites it when stopped, pending an IBI.
  - The application can ACK or NACK the IBI based on the IBI address in the [MSTATUS](#) register.
  - This mode chooses whether there is an IBI byte or not when accepting.

Accurate timestamping of I3C target data is supported in I3C though Async Mode 0. In I3C Asynchronous Timing Control mode, a target device timestamp event occurs within that target. The target notifies the controller about the event by generating an IBI.

### 39.3.2.6 Assigning dynamic addresses to I3C devices

If Dynamic Addresses (DAs) are all assigned below 40h (seven-bit values from 3Fh down to 03h, except where not allowed), then [MIBIRULES\[MSB0\]](#) can be 1. This setting optimizes the START timing. When dynamic addresses are assigned, the [Controller In-band Interrupt Registry and Rules \(MIBIRULES\)](#) register must be programmed based on which I3C target uses IBI bytes (known from Bus Characteristics Register (BCR)).

Any Set Dynamic Address from Static Address (SETDASA) assignments can be done via the normal Common Command Code (CCC) model. These assignments cannot be done when using the static address for the directed part.

There is a built-in mechanism to process the Dynamic Address Assignment (DAA) mode.

1. Set up interrupts (see [Controller Interrupt Set \(MINTSET\)](#)):
  - MCTRLDONE. Indicates when a target has sent its ID and BCR or DCR, and a new DA is needed.

- COMPLETE. Indicates when DAA is done (NACKed by all targets).
  - RXPEND. Indicates the reading of the IDs of the targets. Can also be used to allow DMA to read out bytes.
  - IBIWON. Indicates when an IBI has occurred, which should not be possible normally.
  - MERRWARN. Indicates an error.
2. Configure the [Controller Control \(MCTRL\)](#) register.
    - Write 4 to [MCTRL\[REQUEST\]](#) (ProcessDAA).
    - Set [MCTRL\[IBIRESP\]](#) to IBI response, if possible. If it is not possible, set to the first target assignment.
  3. Wait for the MCTRLDONE interrupt, while reading ID using the RXPEND interrupt. If [MSTATUS\[STATE\]](#) = 5 (DAA mode) and [MSTATUS\[BETWEEN\]](#) = 1, it is waiting for a DA for the target whose ID was read.
    - Write the dynamic address into the [Controller Write Data Byte \(MWDATAB\)](#) register using bits 6:0, such as 14h for DA = 7'h14.
    - Write 4 to [MSTATUS\[STATE\]](#) (ProcessDAA again). This option writes the DA, then moves to the next DA.
    - If [MSTATUS\[COMPLETE\]](#) = 1 and [MSTATUS\[STATE\]](#) = 0, then all targets have been assigned.
    - If MSTATUS indicates NACK after writing a new DA, the DA was not accepted by the target. The next step is to write 2 to [MCTRL\[REQUEST\]](#) (EmitStop) and start over. It is also acceptable to write 4 to [MCTRL\[REQUEST\]](#) (ProcessDAA again).

### 39.3.2.7 Using Controller Message mode

Controller Message mode is intended for use with DMA, though Message mode can also be used by the processor. In Message mode, all writes are to the same location, including the control and the data. Reads occur from an associated location.

#### NOTE

The data writes for message mode work in the same way as the halfword access registers [Controller Write Data Halfword \(MWDATAH\)](#) and [Controller Read Data Halfword \(MRDATAH\)](#).

To send a message via Single Data Rate (SDR), follow these steps (from DMA or processor):

1. Write the control request to the [Controller Write Message Control in SDR mode \(MWMSG\\_SDR\\_CONTROL\)](#) register. This request includes:
  - The address
  - I2C or I3C
  - Read or write
  - The count of bytes to process
  - How to end (on STOP or ready for repeated START)
2. Process the Data.
  - For write operations, write the rest of the data to [Controller Write Message Data in SDR mode \(MWMSG\\_SDR\\_DATA\)](#). Use the DMA trigger (or interrupt) to keep the Transmit FIFO full, and the controller stops using the data when the program count MWMSG\_SDR\_CONTROL register reaches 0.
  - For read operations, a DMA trigger (or interrupt) indicates when the RX FIFO is ready to be read out via the [Controller Read Message in SDR mode \(MRMSG\\_SDR\)](#) register.
3. In-band Interrupt (IBI) behavior is selected in [MCTRL\[IBIRESP\]](#).
4. To exit Message mode with the original message, use END type STOP ([MCTRL\[REQUEST\]](#) = 2) with a zero-length message or by using the MCTRL register.

To send a message via Double Data Rate (DDR), follow these steps (from DMA or processor):

1. Write the control request to the [Controller Write Message in DDR mode: First Control Word \(MWMSG\\_DDR\\_CONTROL\)](#) register. This request includes:
  - The count of byte-pairs.
  - How to end (on HDR Exit or ready for HDR Restart).
2. Write the second control data to MWMSG\_DDR\_CONTROL. This second write includes:
  - The address.
  - Read or write.
  - The seven-bit command value.
3. Process the Data:
  - For write operations, write the rest of the data to MWMSG\_DDR\_DATA. Use the DMA trigger (or interrupt) to keep the Transmit FIFO full, and the controller stops using the data when the program count MWMSG\_DDR\_CONTROL register reaches 0.
  - For read operations, a DMA trigger (or interrupt) indicates when the RX FIFO is ready to be read out.
4. In-band Interrupt (IBI) behavior is selected in [MCTRL\[IBIRESP\]](#).
5. To exit DDR Message mode with the original message, use END type Exit (MCTRL[REQUEST] = 6) with a zero-length message or by using the MCTRL register.

### 39.3.2.8 Handing off controllership to another target and getting it back

To hand off controllership, the controller can do one of two things:

- Wait for a Controller Request (CR) (that is, an [MSTATUS\[IBIWON\]](#) = 1 interrupt), indicating that the CR is using [MSTATUS\[IBITYPE\]](#).
- Push the request manually.

In either case, the controller sends a GETACCMST request, which is a directed GET informing the target that the target is being assigned controllership. If the target accepts this request, it returns its Dynamic Address in bits 7:1 and the negative parity of its dynamic address in bit 0. A STOP must be issued, and [MCONFIG\[MSTENA\]](#) must be set to 2 (switching to the Target mode).

To gain controllership, the target sends an CR using the SCTRL register.

- If MCONFIG[MSTENA] is 2, the GETMSTACC CCC accepts.
- If MCONFIG[MSTENA] is not 2, the GETMSTACC CCC refuses.

After controllership has been granted, [MSTATUS\[NOWMASTER\]](#) is 1. The application must enable the [MINTSET\[NOWMASTER\]](#) bit, so the application is interrupted when a controllership transfer occurs.

### 39.3.2.9 Controller engine flow diagram



Figure 171. Controller engine flow diagram for SDR (HDR flow progresses from SDR bytes)

### 39.3.2.10 Target data write from controller

When the address match is valid for the target Dynamic Address and the type is W (write from controller), the target ACKs the address. It does so unless some condition prevents it, such as a full buffer. On ACK, the WRITE state is entered. Once ACKed, it waits for each complete data byte. This process occurs in two steps:

1. Eight bits are clocked in and stored in the next buffer location while in the WRITE state.
2. On the ninth bit:
  - In I3C mode, the W9TH state (In I3C the ninth data bit written by the Controller is the Parity of the preceding eight Data bits.) is used and the parity is checked. The buffer is marked as complete with or without a parity error.
  - In I2C mode, the W9TH state (In I2C, the ninth Data bit written by the Controller is an ACK by the Target.) is used and the data is ACKed and stored.

When the address match is valid for the 7Eh broadcast address, the target acknowledges it. On the first data complete, it sets the in\_ccc Broadcast or Direct flag (based on bit 7 of the command). If recognized, it parses the command, setting that bit as well. The

recognized commands are for Dynamic Address work and modes. The CCC and DAA blocks handle the workload afterward. If not supported, then the commands are passed up to the system.

### 39.3.2.11 Target data write to controller

When the address match is valid for the target Dynamic Address, and the type is R (read by controller), the target ACKs the address. The target does so unless there is no data waiting for the read. On ACK, the READ state is entered.

Once ACKed, it emits the data byte at a time, with the ninth bit using R9TH state. (In I2C, the ninth Data bit from Target to Controller is an ACK by the Controller. In I3C this bit allows the Target to end a Read, and allows the Controller to Abort a Read.)

- In I3C mode, the T bit is emitted to allow the device to indicate whether this byte is the last (from input signal from upper layers). If it is not last byte, the controller may terminate the read via the T bit.
- In I2C mode, the ninth bit allows the controller to terminate via NACK, or else it allows the read to continue via ACK. On completion of each byte read, the done signal is pulsed to get the next byte.

If the read is terminated by the controller unexpectedly (abort in I3C, NACK before END marked), the application is notified.

### 39.3.3 Clocking

The controller block has following basic clocks feeding:

- The system clock, which controls the access to the memory mapped registers.
- A functional clock (FCLK), which is used to generate the SCL clock rate on the I2C or I3C bus.

I3C supports adjusting clock frequency and accuracy via the [Target Time Control Clock \(STCCLOCK\)](#) register.

CLK\_SLOW is used to check conditions like Bus Availability, Bus Free for IBI, or Hot-Join. The slow clock helps to save power.

- To determine the Bus Available condition for IBI, the target needs a clock to generate the ~1 µs timing. To support this requirement, a slow clock (CLK\_SLOW) is provided to save on power.
- I3C supports a counter field, [SCONFIG\[BAMATCH\]](#), to calculate the Bus Available condition. BAMATCH provides the count of the slow clock. This field counts 1 µs or more to allow an IBI to drive SDA low when the controller is free. The maximum width and maximum values are controlled by the I3C module.

I3C supports a timeout when stalled too long in a frame. This timeout occurs when:

- The Transmit FIFO or Receive FIFO is not handled and the bus is stuck in the middle of a message.
- No STOP was issued and the bus is between messages.
- IBI manual is used and no decision was made.

### 39.3.4 Reset

The resets are:

- Global/system reset fed into block. Everything is reset by this global/system reset. Release is assumed to be synchronized to the system clock. It is not synchronized to SCL or SDA. Those signals should not be active when the reset is released; otherwise, I3C would be in Hot-Join mode and therefore not active.
- A software reset is provided.
- STOP state is reset by a START as well.

#### 39.3.4.1 Target Reset and RSTACT CCC

The Target Reset mechanism is designed to allow an always-on tiny block to monitor SDA and SCL for a specific pattern based on HDR Exit - extended with repeated START and STOP at the end. This detector can be used to wake or reset the device or just a peripheral, as well as do nothing for any specific reset. The normal use is that the controller emits a RSTACT CCC message saying not to reset when this pattern is emitted just after; devices which are broken reset (since they miss the CCC) and devices in deepest sleep (for example, an unpowered core domain) wake (since they also miss the CCC).

The 1st default action is only to reset the peripheral. If that does not work, the next time will reset the chip/system.

The controller may also request a specific action, which the target can dial in if it supports that (for example, reset the peripheral only).

The Target Reset is connected into the system as shown in [Figure 172](#). Note that it is outside of the I3C Peripheral, and may be in an always-on domain. Sleep/wake signals are not shown. The common connections are as follows:

**Table 232. Target resets**

| Reset detector   | Connect to System       | Notes                                                                                 |
|------------------|-------------------------|---------------------------------------------------------------------------------------|
| I3c_slave_active | If I3C can be unused    | Connect to enable if can be unused<br>— should probably not clear for safety reasons. |
| iRstAction[3:0]  | —                       | Result of RSTACT CCC                                                                  |
| oRstRstAction    | —                       | Clear RSTACT state                                                                    |
| oResetBlock      | —                       | Triggers IRQ in IP                                                                    |
| oRstAll          | System reset            | Should perform similar to pin RSTn                                                    |
| oRstCustom       | Custom Reset if enabled | Must be setup via RSTACT_CONFIG[2]                                                    |



**Figure 172. Target reset detector connected in the system (Target Reset may be in Always-on domain)**

[Figure 173](#) shows the connections of the Target Reset detector, including support for deepest sleep and wake. If those are not used, they are just not connected. If the I3C peripheral may be powered off when the reset detector is powered, the isolation cells are used to protect it, although the nets are logically gated off when iDeepestSleep is 1.

Note that the block wants the SCL and SDA signals to be fed as clocks. This is done outside the block, using any method needed. 3 domains are needed to support the reset.



Figure 173. Showing reset detector connections — not all used in many systems

The i3c\_slave\_active signal must be used with caution, as it disables the reset detector when 0; it should be strapped 1 if always i3c and target, else should be safely controlled (or may defeat the purpose of the Target Reset block). If the I3C peripheral is optional, then it must be selected by some system control feature - that should be what controls i3c\_slave\_active.

The block is connected to the I3C peripheral through the iRstAction and oRstRstAction ports. These are clamped off if iDeepestSleep signal is 1; if that kind of sleep is not possible, the iDeepestSleep port should be strapped 0. The 2 nets can be treated as asynchronous even though from the same SCL. This is to avoid having to do setup/hold timing between the modules when the reset detector is in a separate domain. That is, the clk\_SCL and clk\_SDA\_n are not intended to be treated the same clocks as used in the peripheral - this allows freedom in placement of the detector.

Finally, the reset and wake signals are connected to the system; they are 0 when inactive, 1 when actively driven. There are clearing events used to clear: RstAll waits for the Reset input to assert (or i3c\_active to go to 0); the RstBlock waits for the I3C peripheral to clear its cause register or to see a RSTACT or GETSTATUS. Wake clears on release of iDeepestSleep.

### 39.3.5 Interrupts

This section describes all the interrupts (IRQs) that this module generates. All status interrupts are updated in the [Controller Status \(MSTATUS\)](#) and [Target Status \(SSTATUS\)](#) registers.

Supported interrupts occur:

- For pending IBI, CR, or Hot-Join that have been sent by a target.
- When a CCC is received and is handled by the block ([SSTATUS\[CHANLED\]](#)).
- When an error or warning has occurred, such as data underrun, data overrun, parity error, HDR-DDR, or CRC error.

## 39.4 External signals

| Signal | Description                                                                                                                                                                                                                  | Direction       |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|
| SCL    | Serial clock                                                                                                                                                                                                                 | Input or output |
| SDA    | Serial data                                                                                                                                                                                                                  | Input or output |
| PUR    | Pull up resistance. There is internal pull-up resistance on SDA, which is controlled by the I3C controller. If the internal pullup is not enough, PUR can be used to control an external pull-up resistance on SDA actively. | Output          |

## 39.5 Initialization

### 39.5.1 Configuration initialization for controller

The configuration is handled when initializing this module. Configuration is done using the [Controller Configuration \(MCONFIG\)](#) register, which controls the frequencies, duty cycle, optimizations for performance, and other parameters.

Table 233. Configuration used to initialize the module

| Configuration parameter |                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MSTENA                  | Controller Enable | Determines whether the peripheral starts in Controller mode (Main Controller in I3C terms) or starts in Target mode (and switches to Controller mode later).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| HKEEP                   | High Keeper       | Determines how the high-keeper (weak pullup) is implemented, depending on the device capabilities.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| PPBAUD                  | Push-Pull Baud    | <p>Sets the push-pull frequency as a divider from the FCLK (alternative clock fed to the peripheral). This frequency sets the SCL half-clock period baseline (used at least for the high time of SCL).</p> <p>The formula for SCL in Push-Pull mode using PPBAUD and PPLOW is:</p> $\text{SCL freq (in MHz)} = \text{FCLK} / ((2 + 2 * \text{PPBAUD}) + \text{PPLOW})$ <p>If PPLOW is 0, then SCL high = SCL low (in ns) = <math>(1 + \text{PPBAUD}) * 1000 / \text{FCLK}</math> (in MHz)</p> <p>Examples:</p> <ul style="list-style-type: none"> <li>• If FCLK = 24 MHz, then PPBAUD = 0 yields 12 MHz (42.67 ns per half period)</li> <li>• If FCLK = 50 MHz, then PPBAUD = 1 yields 12.5 MHz (20 + 20 = 40 ns per half period)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                            |
| PPLOW                   | Push-Pull Low     | <p>Changes the duty cycle for Push-Pull. It indicates how many more FCLK cycles to use for low.</p> <p>The formula for SCL in Push-Pull mode using PPBAUD and PPLOW is:</p> $\text{SCL freq (in MHz)} = \text{FCLK} / ((2 + 2 * \text{PPBAUD}) + \text{PPLOW})$ <p>If PPLOW is non-zero, then</p> <ul style="list-style-type: none"> <li>• SCL High (in ns) = <math>(1 + \text{PPBAUD}) * 1000 / \text{FCLK}</math> (in MHz)</li> <li>• SCL Low (in ns) = <math>(1 + \text{PPBAUD} + \text{PPLOW}) * 1000 / \text{FCLK}</math> (in MHz)</li> </ul> <p>For example, when FCLK is 50 MHz, PPBAUD is 1, and PPLOW is 1, then the periods are:</p> <ul style="list-style-type: none"> <li>• <math>(1 + 1) * 1000 / 50 = 20 + 20 = 40</math> ns high</li> <li>• <math>(1 + 1 + 1) * 1000 / 50 = 20 + 20 + 20 = 60</math> ns low</li> </ul> <p>This timing is equivalent to 10 MHz SCL, but this timing maintains the 40 ns high needed so I2C devices do not see the high periods.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>The PPLOW value does not have any impact on Open-Drain mode and I2C mode SCL rate calculations.</p> |
| ODBAUD                  | Open Drain Baud   | <p>The number of PPBAUD periods to make up one I3C Open-Drain half-clock baseline.</p> <p>If ODHPP is 0, the ODBAUD half-clock time period = <math>(\text{ODBAUD} + 1) * \text{PPBAUD}</math> high period</p> <p>If ODHPP is 0, the formula for SCL in Open-Drain mode is:</p> $\text{SCL (in MHz)} = \text{FCLK} / (2 + 2 * \text{PPBAUD}) * (\text{ODBAUD} + 1)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

*Table continues on the next page...*

Table 233. Configuration used to initialize the module (continued)

| Configuration parameter | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | <p>Target to get open-drain half-clock period is 200 ns.</p> <p>For example:</p> <ul style="list-style-type: none"> <li>If PPBAUD yields 12.5 MHz (40 ns per PPBAUD period), then ODBAUD = 4 can be used to get 200 ns. See also ODHPP for details on short High and long Low.</li> <li>If PPBAUD = 1, FCLK = 50 MHz, and ODBAUD = 4, then open-drain SCL = <math>50 / (2 + 2 * 1) * 5 = 2.5</math> MHz.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| ODHPP                   | <p>Open-Drain High Push-Pull</p> <p>Optional field that allows the I3C open-drain to be long low and short high. The High period of SCL is the PPBAUD period. This period leaves enough time for the pull-up resistor to pull the SDA high when SCL is low. It is also quick when SCL is high and there are no changes happening.</p> <p>ODBAUD low half-clock time period = <math>(ODBAUD + 1) * PPBAUD</math> high period.</p> <p>ODBAUD high half-clock time period = PPBAUD high period</p> <p>If ODHPP is 1, the formula for SCL in Open-Drain mode is:</p> $SCL \text{ (in MHz)} = FCLK / (1 + PPBAUD) * (ODBAUD + 1) + (1 + PBAUD)$ <p>For example:</p> <ul style="list-style-type: none"> <li>If PPBAUD produces 12.5 MHz (40 ns per PPBAUD period), then ODBAUD = 4 and ODHPP = 1. These settings provide a high period of 40 ns and a low period of 200 ns.</li> <li>If PPBAUD = 1, FCLK = 50 MHz, and ODBAUD = 4 then open-drain SCL = <math>50 / (1 + 1) * 5 + (1 + 1) = 4.16</math> MHz.</li> </ul> |
| I2CBAUD                 | <p>I2C Baud</p> <p>Indicates how many ODBAUD periods are required to communicate with I2C devices (<a href="#">MCTRL[TYPE]</a> = 2 or <a href="#">MWMSG_SDR_CONTROL[I2C]</a> = 1).</p> <p>For example, if ODBAUD gives 200 ns, and the goal is Fm+ (Fast Mode, 1 MHz), then the sum must be 1 <math>\mu</math>s.</p> <p>I2CBAUD acts differently for odd and even values. For example:</p> <ul style="list-style-type: none"> <li>If I2CBAUD = 3, it gives 3 ODBAUD periods low and 2 ODBAUD periods high.</li> <li>If I2CBAUD = 4, then it gives 4 ODBAUD periods for low and 4 ODBAUD periods for high.</li> <li>Also, if I2CBAUD = 3, this yields <math>200 * 3 = 600</math> ns and <math>200 * 2 = 400</math> ns, with the sum <math>600 + 400 = 1000</math> ns = 1 <math>\mu</math>s.</li> </ul>                                                                                                                                                                                                            |
| SKEW                    | <p>Skew</p> <p>The normal SDA skew from SCL is handled by using the time for the SCL to reach its pad and come back to the design. This time is normally 2 ns to 5 ns (or sometimes more). If the SKEW is too fast, then add more delay, the SKEW allows specifying the number of FCLKs to insert.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

Additional optimizations:

- Use [MIBIRULES\[MSB0\]](#) to obtain faster START header times. If the controller application assigns all I3C dynamic addresses to be less than 40h (it does not have MSB set), MIBIRULES[MSB0] can be set. When the controller emits 7Eh (broadcast) and a target does not drive the first bit low, the rest of the header can be at push-pull speeds. This speed is two times faster or more, depending on optimizations.
- Auto-emit 7Eh speeds up the frame when used with MIBIRULES[MSB0]. It allows the processor to sleep when the frame starts automatically (in response to a target).

### 39.5.2 Interrupt service flow

Set up interrupts for [Controller Status \(MSTATUS\)](#) in [Controller Interrupt Set \(MINTSET\)](#).

Set up interrupts for [Target Status \(SSTATUS\)](#) in [Target Interrupt Set \(SINTSET\)](#).

## 39.6 Application information

### 39.6.1 I2C configuration for meeting timing requirement for Fm and Fm+ modes

I2C Fm and I2C Fm+ mode is supported as per the I3C standard specifications.

Configuration for Fm mode (Below configurations are to meet close to 400 kHz) But In this case  $T_{SU\_STA}$  is not met:

Table 234. Configuration for Fm mode, where frequency is close to 400 kHz but timing requirement is not met

| FCLK   | PPBAUD | ODBAUD | I2CBAUD | SCL FREQ | Timing Requirement violations |
|--------|--------|--------|---------|----------|-------------------------------|
| 24 MHz | 0      | 4      | 11      | 370 kHz  | $T_{SU\_STA}$ - 353 ns        |

Table 235. Configuration for Fm mode, where all timing requirements are met

| FCLK   | PPBAUD | ODBAUD | I2CBAUD | SCL FREQ | Timing Requirement met? |
|--------|--------|--------|---------|----------|-------------------------|
| 24 MHz | 1      | 2      | 9       | 363 kHz  | Yes                     |

Configuration for Fm+ mode, where the frequency is close to 1 MHz. Although, in this case the  $T_{SU\_STA}$  timing requirement is not met.

Table 236. Configuration for Fm+ mode, where frequency is close to 1 MHz but timing requirement is not met

| FCLK   | PPBAUD | ODBAUD | I2CBAUD | SCL FREQ | Timing Requirement violations |
|--------|--------|--------|---------|----------|-------------------------------|
| 24 MHz | 0      | 4      | 3       | 960 kHz  | $T_{SU\_STA}$ - 228 ns        |

To meet all the timing specifications, frequency may differ from 1 MHz. Use the following configurations.

Table 237. Configuration for Fm+ mode, where all timing requirements are met

| FCLK   | PPBAUD | ODBAUD | I2CBAUD | SCL FREQ | Timing Requirement met? |
|--------|--------|--------|---------|----------|-------------------------|
| 24 MHz | 0      | 3      | 6       | 749 kHz  | Yes                     |

#### NOTE

The controller module provides an option to slow down the clock for standard speed mode to support legacy I2C standard targets as well. Although, this option may not necessarily meet the exact timing requirement of the standard mode per the standard I2C timing specification.

For the timing requirements under consideration, see the "I3C Timing Requirements When Communicating With I2C Legacy Devices" table in the MIPI I3C v1.1.1 specification available on [www.mipi.org](http://www.mipi.org).

## 39.7 I3C register descriptions

Writing to a read-only (RO) register, except to [Controller Interrupt Mask \(MINTMASKED\)](#), causes bus errors. I3C does not verify whether programmed values in the registers are correct. You must ensure that valid programmed values are written.

However, the peripheral ignores writes to RO registers and returns 0 for reads from WO or nonexistent registers. It requires all 32-bit registers to be read and written as 32-bit and aligned to 32 bits. The peripheral uses the advanced peripheral bus (APB):

AMBA 3 APB Protocol Specification v1.0); therefore, the peripheral does not know whether partial read or write operations (less than 32 bits) are used.

### 39.7.1 I3C memory map

I3C0 base address: 4000\_2000h

| Offset | Register                                        | Width<br>(In bits) | Access | Reset value                 |
|--------|-------------------------------------------------|--------------------|--------|-----------------------------|
| 0h     | Controller Configuration (MCONFIG)              | 32                 | RW     | 0000_0000h                  |
| 4h     | Target Configuration (SCONFIG)                  | 32                 | RW     | 0017_0000h                  |
| 8h     | Target Status (SSTATUS)                         | 32                 | RW     | 0000_1400h                  |
| Ch     | Target Control (SCTRL)                          | 32                 | RW     | 0000_0000h                  |
| 10h    | Target Interrupt Set (SINTSET)                  | 32                 | RW     | 0000_0000h                  |
| 14h    | Target Interrupt Clear (SINTCLR)                | 32                 | RW     | <a href="#">See section</a> |
| 18h    | Target Interrupt Mask (SINTMASKED)              | 32                 | R      | 0000_0000h                  |
| 1Ch    | Target Errors and Warnings (SERRWARN)           | 32                 | RW     | 0000_0000h                  |
| 20h    | Target DMA Control (SDMACTRL)                   | 32                 | RW     | 0000_0010h                  |
| 2Ch    | Target Data Control (SDATACTRL)                 | 32                 | RW     | 8000_0030h                  |
| 30h    | Target Write Data Byte (SWDATAB)                | 32                 | RW     | <a href="#">See section</a> |
| 34h    | Target Write Data Byte End (SWDATABASE)         | 32                 | RW     | <a href="#">See section</a> |
| 38h    | Target Write Data Half-word (SWDATAH)           | 32                 | RW     | <a href="#">See section</a> |
| 3Ch    | Target Write Data Half-word End (SWDATAHE)      | 32                 | RW     | <a href="#">See section</a> |
| 40h    | Target Read Data Byte (SRDATAB)                 | 32                 | R      | 0000_0000h                  |
| 48h    | Target Read Data Halfword (SRDATAH)             | 32                 | R      | <a href="#">See section</a> |
| 54h    | Target Write Data Byte (SWDATAB1)               | 32                 | RW     | 0000_0000h                  |
| 54h    | Target Write Data Halfword (SWDATAH1)           | 32                 | RW     | 0000_0000h                  |
| 5Ch    | Target Capabilities 2 (SCAPABILITIES2)          | 32                 | R      | 0000_0300h                  |
| 60h    | Target Capabilities (SCAPABILITIES)             | 32                 | R      | E83F_FE70h                  |
| 64h    | Target Dynamic Address (SDYNADDR)               | 32                 | RW     | 0000_0000h                  |
| 68h    | Target Maximum Limits (SMAXLIMITS)              | 32                 | RW     | 0000_0000h                  |
| 6Ch    | Target ID Part Number (SIDPARTNO)               | 32                 | RW     | 3000_0000h                  |
| 70h    | Target ID Extension (SIDEXT)                    | 32                 | RW     | 0066_EF00h                  |
| 74h    | Target Vendor ID (SVENDORID)                    | 32                 | RW     | 0000_011Bh                  |
| 78h    | Target Time Control Clock (STCCLOCK)            | 32                 | RW     | 0000_3014h                  |
| 7Ch    | Target Message Map Address (SMSGMAPADDR)        | 32                 | R      | 0000_0000h                  |
| 80h    | Controller Extended Configuration (MCONFIG_EXT) | 32                 | RW     | 0000_0000h                  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset | Register                                                                        | Width<br>(In bits) | Access | Reset value                 |
|--------|---------------------------------------------------------------------------------|--------------------|--------|-----------------------------|
| 84h    | Controller Control (MCTRL)                                                      | 32                 | RW     | 0000_0000h                  |
| 88h    | Controller Status (MSTATUS)                                                     | 32                 | RW     | 0000_1000h                  |
| 8Ch    | Controller In-band Interrupt Registry and Rules (MIBIRULES)                     | 32                 | RW     | 0000_0000h                  |
| 90h    | Controller Interrupt Set (MINTSET)                                              | 32                 | RW     | 0000_0000h                  |
| 94h    | Controller Interrupt Clear (MINTCLR)                                            | 32                 | RW     | <a href="#">See section</a> |
| 98h    | Controller Interrupt Mask (MINTMASKED)                                          | 32                 | R      | 0000_0000h                  |
| 9Ch    | Controller Errors and Warnings (MERRWARN)                                       | 32                 | RW     | 0000_0000h                  |
| A0h    | Controller DMA Control (MDMACTRL)                                               | 32                 | RW     | 0000_0010h                  |
| ACh    | Controller Data Control (MDATACTRL)                                             | 32                 | RW     | 8000_0030h                  |
| B0h    | Controller Write Data Byte (MWDTAB)                                             | 32                 | RW     | <a href="#">See section</a> |
| B4h    | Controller Write Data Byte End (MWDTABE)                                        | 32                 | RW     | <a href="#">See section</a> |
| B8h    | Controller Write Data Halfword (MWDTAH)                                         | 32                 | RW     | <a href="#">See section</a> |
| BCh    | Controller Write Data Halfword End (MWDTAHE)                                    | 32                 | RW     | <a href="#">See section</a> |
| C0h    | Controller Read Data Byte (MRDTAB)                                              | 32                 | R      | 0000_0000h                  |
| C8h    | Controller Read Data Halfword (MRDTAH)                                          | 32                 | R      | 0000_0000h                  |
| CCh    | Controller Write Byte Data 1(to bus) (MWDTAB1)                                  | 32                 | RW     | 0000_0000h                  |
| CCh    | Controller Write Halfword Data (to bus) (MWDTAHE1)                              | 32                 | RW     | 0000_0000h                  |
| D0h    | Controller Write Message Control in SDR mode<br>(MWMSG_SDR_CONTROL)             | 32                 | RW     | <a href="#">See section</a> |
| D0h    | Controller Write Message Data in SDR mode<br>(MWMSG_SDR_DATA)                   | 32                 | RW     | 0000_0000h                  |
| D4h    | Controller Read Message in SDR mode (MRMSG_SDR)                                 | 32                 | R      | 0000_0000h                  |
| D8h    | Controller Write Message in DDR mode: First Control Word<br>(MWMSG_DDR_CONTROL) | 32                 | RW     | <a href="#">See section</a> |
| D8h    | Controller Write Message in DDR mode Control 2<br>(MWMSG_DDR_CONTROL2)          | 32                 | RW     | <a href="#">See section</a> |
| D8h    | Controller Write Message Data in DDR mode<br>(MWMSG_DDR_DATA)                   | 32                 | RW     | 0000_0000h                  |
| DCh    | Controller Read Message in DDR mode (MRMSG_DDR)                                 | 32                 | R      | 0000_0000h                  |
| E4h    | Controller Dynamic Address (MDYNADDR)                                           | 32                 | RW     | 0000_0000h                  |
| 11Ch   | Map Feature Control 0 (SMAPCTRL0)                                               | 32                 | R      | 0000_0000h                  |
| 140h   | Extended IBI Data 1 (IBIEXT1)                                                   | 32                 | RW     | 0000_0070h                  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset | Register                      | Width<br>(In bits) | Access | Reset value |
|--------|-------------------------------|--------------------|--------|-------------|
| 144h   | Extended IBI Data 2 (IBIEXT2) | 32                 | RW     | 0000_0000h  |
| FFCh   | Target Module ID (SID)        | 32                 | R      | EDCB_0100h  |

### 39.7.2 Controller Configuration (MCONFIG)

#### Offset

| Register | Offset |
|----------|--------|
| MCONFIG  | 0h     |

#### Function

Controls all controller states when the controller operation is enabled. You must not change this register during an active transaction.

#### Diagram

| Bits  | 31      | 30 | 29 | 28 | 27     | 26 | 25 | 24        | 23           | 22         | 21    | 20    | 19 | 18     | 17 | 16 |
|-------|---------|----|----|----|--------|----|----|-----------|--------------|------------|-------|-------|----|--------|----|----|
| R     | I2CBAUD |    |    |    | SKEW   |    |    | ODHP<br>P | ODBAUD       |            |       |       |    |        |    |    |
| W     | 0       | 0  | 0  | 0  | 0      | 0  | 0  | 0         | 0            | 0          | 0     | 0     | 0  | 0      | 0  | 0  |
| Reset | 0       | 0  | 0  | 0  | 0      | 0  | 0  | 0         | 0            | 0          | 0     | 0     | 0  | 0      | 0  | 0  |
| Bits  | 15      | 14 | 13 | 12 | 11     | 10 | 9  | 8         | 7            | 6          | 5     | 4     | 3  | 2      | 1  | 0  |
| R     | PPLOW   |    |    |    | PPBAUD |    |    |           | Reserv<br>ed | ODST<br>OP | HKEEP | DISTO | 0  | MSTENA |    |    |
| W     | 0       | 0  | 0  | 0  | 0      | 0  | 0  | 0         | 0            | 0          | 0     | 0     | 0  | 0      | 0  | 0  |
| Reset | 0       | 0  | 0  | 0  | 0      | 0  | 0  | 0         | 0            | 0          | 0     | 0     | 0  | 0      | 0  | 0  |

#### Fields

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-28<br>I2CBAUD | <p>I2C Baud Rate</p> <p>Specifies the I2C low and high times in ODBAUD counts:</p> <ul style="list-style-type: none"> <li>I2CBAUD &gt;&gt; 1 is the main count load, and it is count - 1. So, I2CBAUD &gt;&gt; 1: I2CBAUD = 0 for one ODBAUD beat and I2CBAUD = 1 for two ODBAUD beats.</li> <li>If I2CBAUD[28] is 1, then the low time has one extra ODBAUD beat. The I2CBAUD field is normally 3, where ODBAUD gives 200 ns. For I2CBAUD &gt;&gt; 1, I2CBAUD = 1, which means two ODBAUD beats. To meet the requirements for Fast-mode Plus (Fm+), <math>(2 + 1) * 200 = 600</math> ns low, with <math>2 * 200 = 400</math> ns high for 1 <math>\mu</math>s period. For Fast mode (Fm), I2CBAUD is normally 11 (giving 2.6 <math>\mu</math>s) or 6 (giving 2.4 <math>\mu</math>s).</li> </ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27-25<br>SKEW   | <p>Skew</p> <p>Specifies the number of FCLK counts for an SDA change after SCL for I3C push-pull. This skew is in addition to the roundtrip of the SCL line from the pad back to I3C (6 ns or more):</p> <ul style="list-style-type: none"> <li>• SKEW is normally not needed, so assign SKEW = 0.</li> <li>• SKEW is only used if SDA is not naturally skewing from an SCL change.</li> <li>• I2C automatically skews SDA (but not PUR) to match I2C rules.</li> </ul> <p>Use the following values:</p> <ul style="list-style-type: none"> <li>• In I2C Controller mode (<a href="#">MCONFIG[MSTENA]</a> = 11b) <ul style="list-style-type: none"> <li>— SKEW &gt; 0 when clock stretching feature is not required.</li> <li>— SKEW = 0 when clock stretching feature is required.</li> </ul> </li> <li>• In I3C Controller mode, use SKEW = 0.</li> </ul> |
| 24<br>ODHPP     | <p>Open Drain High Push-Pull</p> <p>Enables ODHPP. If you write 0 to this field, open-drain SCL high half-clock period is the same as the open-drain low SCL half-period. If you write 1 to this field, open-drain high SCL half-lock period is one PPBAUD count for I3C messages. This setting is faster (and works for I3C devices). Any legacy I2C devices on the bus do not see the SCL high at all (less than the spike filter period). For open-drain timing, check upon the first 7Eh broadcast allowing I3C peripherals acting as I2C legacy devices to turn off their I2C 50-ns spike filters. See <a href="#">Sending a CCC to I3C targets</a> for more information.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                      |
| 23-16<br>ODBAUD | <p>Open Drain Baud Rate</p> <p>Specifies the open drain baud rate.</p> <p>ODBAUD = (in terms of number of PPBAUD counts) - 1.</p> <p>This field must not be 0; this setting is not the same as push-pull. See <a href="#">Configuration initialization for controller</a> for more information.</p> <p>The open-drain baud rate is usually 200 ns (see I2CBAUD for I2C counts). When used with <a href="#">MCONFIG[ODHPP]</a>, this setting produces 250 ns per clock in I3C. In this case, if <a href="#">MCONFIG[PPBAUD]</a> provides 12 MHz, then one PPBAUD count is half of 12 MHz, or 41.67 ns. To obtain a rate around 200 ns, use a value of 5 - 1 = 4 for ODBAUD.</p>                                                                                                                                                                              |
| 15-12<br>PPLOW  | <p>Push-Pull Low</p> <p>Acts as an adder for push-pull low to create a duty-cycle with a longer low period, with up to 15 more FCLK cycles low than high. PPLOW = 0 produces a 50/50 duty cycle.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 11-8<br>PPBAUD  | <p>Push-Pull Baud Rate</p> <p>Specifies the push-pull baud rate.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | <p>The number of FCLK counts makes each push-pull low and normally high period. PPBAUD = 0 when run at 1/2 input FCLK speed. For example, a 24 MHz FCLK produces a 12 MHz SCL because each FCLK is SCL low or SCL high.</p> <p><b>MCONFIG[PPLOW]</b> has an effect on the duty cycle. For example, 24 MHz with 50/50 duty cycle is 12 MHz. However, when PPLOW adds three more low beats, the push-pull baud rate becomes 4.8 MHz (from 24 MHz or 5 beats).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 6<br>ODSTOP  | <p><b>Open Drain Stop</b></p> <p>Enables open-drain stop. If you write 0 to this field, open-drain stop is disabled. ODSTOP must be disabled when sending an HDR exit pattern. If you write 1 to this field, open-drain stop is enabled. Stop condition is emitted at open-drain speeds even for I3C messages. In legacy devices, this feature can ensure that the legacy devices see the Stop condition.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 5-4<br>HKEEP | <p><b>High-Keeper</b></p> <p>Indicates how High-Keeper is supported.</p> <p>If this field is 0b, use pull-up resistor (PUR). No separate pin_HK_SDA or pin_HK_SCL is used. Only pin_PUR_oena is used for SDA. Hold pin_SCL_oena high in this mode, SCL clock is push-pull and pin_SCL_out toggles, which is the actual clock.</p> <p>If this field is 1b, High-Keeper controls; use pin_HK_SDA or pin_HK_SCL (High-Keeper) controls. SCL may use an HK or that signal (pin_HK_SCL) may only OR into pin_SCL_oena. Uses pin_HK_SDA as well for SDA high keeper, along with pin_PUR_oena.</p> <p>If this field is 10b, passive on SDA, can Hi-Z (high-impedance) for bus free (Idle) and hold. The pins, pin_HK_SDA and pin_HK_SCL, are not used; only a combination of SDA_oena and pin_PUR_oena are used.</p> <p>If this field is 11b, passive on SDA and SCL, can Hi-Z (high-impedance) both for bus free (Idle), and can Hi-Z SDA for hold. This is for I2C Clock Stretching mode, where both SCL and SDA are open drain.</p> <p style="text-align: center;"><b>NOTE</b><br/>Your chip may not support any or all High-Keeper methods.</p> <p>Use HKEEP = 2/3 for I2C modes.</p> <p>Use HKEEP = 0/1 for I3C modes.</p> <p>00b - None<br/>01b - Wired In<br/>10b - Passive SDA<br/>11b - Passive on SDA SCL</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3<br>DISTO    | <p>Disable Timeout</p> <p>Disables the timeout that produces application errors.</p> <p>If the controller is left in a state other than Stopped for more than 100 µs (because 10 kHz is the slowest allowed I3C speed), the timeout sends a MERRWARN interrupt. To prevent the MERRWARN interrupt during development or testing, write 1 to DISTO to disable the timeout.</p> <p>In systems that support timeouts, timeout is disabled automatically during debug.</p> <ul style="list-style-type: none"> <li>0b - Enabled</li> <li>1b - Disabled, if configured</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1-0<br>MSTENA | <p>Controller Enable</p> <p>Indicates whether the controller is enabled and the states it can use.</p> <p>If this field is 0b, the controller is disabled. I3C can only use Target mode.</p> <p>If this field is 1b, the controller is enabled. When used upon start-up, I3C is the main controller by default. I3C controls the bus unless the controller is handed off. When this happens, this field must become 2 so that it has the capability to become the controller again. Performing the handoff means emitting the GETACCMST CCC command. If the command is accepted, I3C emits a Stop condition and sets this field to 2 (or 0).</p> <p>If this field is 10b, I3C is controller-capable, but is operating as a target now. When used from the start, I3C starts as a target, but is prepared to switch to Controller mode. To switch to this mode, the target emits a controller request (CR) or receives a GETACCMST CCC command and accepts it (to switch on the Stop condition).</p> <p>Legacy I2C—if this field is 11b, I2C Controller mode uses an open-drain clock (to allow clock stretching) and relies on passive pull-up resistors (PURs) on both SCL and SDA. This mode uses only I2CBAUD. Start requests can only be made for I2C type, and I3C requests are not accepted. If there are only I2C targets on the bus and no clock stretching, use type 1 instead. Type 1 has a push-pull SCL clock, which is faster and uses less power.</p> <ul style="list-style-type: none"> <li>00b - Controller off</li> <li>01b - Controller on</li> <li>10b - Controller capable</li> <li>11b - I2C Controller mode</li> </ul> |

### 39.7.3 Target Configuration (SCONFIG)

Offset

| Register | Offset |
|----------|--------|
| SCONFIG  | 4h     |

**Function**

Contains fields that must be configured before the module is activated.

**Diagram**

| Bits  | 31    | 30 | 29 | 28 | 27 | 26      | 25 | 24 | 23 | 22 | 21 | 20   | 19    | 18   | 17   | 16   |
|-------|-------|----|----|----|----|---------|----|----|----|----|----|------|-------|------|------|------|
| R     | SADDR |    |    |    | 0  | BAMATCH |    |    |    |    |    |      |       |      |      |      |
| W     |       |    |    |    |    |         |    |    |    |    |    |      |       |      |      |      |
| Reset | 0     | 0  | 0  | 0  | 0  | 0       | 0  | 0  | 0  | 0  | 0  | 1    | 0     | 1    | 1    | 1    |
| Bits  | 15    | 14 | 13 | 12 | 11 | 10      | 9  | 8  | 7  | 6  | 5  | 4    | 3     | 2    | 1    | 0    |
| R     | 0     |    |    |    | 0  | OFFLI   | NE | 0  | 0  | 0  | 0  | HDRD | S0IGN | MATC | NACK | SLVE |
| W     |       |    |    |    |    |         |    |    |    |    |    | K    | ORE   | HSS  |      | NA   |
| Reset | 0     | 0  | 0  | 0  | 0  | 0       | 0  | 0  | 0  | 0  | 0  | 0    | 0     | 0    | 0    | 0    |

**Fields**

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-25<br>SADDR   | Static Address<br>Sets the I2C 7-bit static address, which otherwise must be 0.                                                                                                                                                                                                                                                                                                               |
| 24<br>—          | Reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| 23-16<br>BAMATCH | Bus Available Match<br>Specifies the bus available condition match value for the current slow clock.<br>BAMATCH provides the count of the slow clock to count out 1 $\mu$ s (or more) to allow an In-Band Interrupt (IBI) to drive SDA low when the controller is not doing so. The I3C module controls the maximum width and maximum values.<br>.                                            |
| 15-12<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| 11-10<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| 9<br>OFFLINE     | Offline<br>Enables wait to ensure that the bus is not in HDR mode.<br>If this field is 1 when <a href="#">SCONFIG[SLVENA]</a> is 1, then the I3C module waits for either 60 $\mu$ s of bus quiet or an HDR exit pattern. This waiting ensures that the bus is not in HDR mode, and so can safely monitor for the next activity in Single Data Rate (SDR) mode.<br>0b - Disable<br>1b - Enable |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                        |
| 7<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                        |
| 6-5<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4<br>HDROK    | <p>HDR OK</p> <p>Enables HDR OK. If you write 1 to this field, it allows HDR-DDR and/or HDR-BT messaging, if available, by writing 1 to the corresponding SIDEXT[BCR] field to indicate HDR is available, and the corresponding GETCAPS field for DDR and/or BT bit permitting use.</p> <p>This is a deprecated field; use the SIDEXT[BCR] field instead.</p> <p>0b - Disable HDR OK<br/>1b - Enable HDR OK</p> |
| 3<br>S0IGNORE | <p>Ignore TE0 or TE1 Errors</p> <p>Ignores TE0 or TE1 errors. If you write 1 to this field, the target does not detect TE0 or TE1 errors, so it does not lock up waiting on an exit pattern. You must not use this setting when the bus does not use HDR mode.</p> <p>0b - Do not ignore TE0 or TE1 errors<br/>1b - Ignore TE0 or TE1 errors</p>                                                                |
| 2<br>MATCHSS  | <p>Match Start or Stop</p> <p>Enables match Start or Stop condition. If you write 1 to this field, <a href="#">SINTSET[START]</a> and <a href="#">SINTSET[STOP]</a> become 1 only when <a href="#">STATUS[MATCHED]</a> is 1. This setting allows the START and STOP fields to be used to detect the end of a message to or from this target.</p> <p>0b - Disable<br/>1b - Enable</p>                            |
| 1<br>NACK     | <p>Not Acknowledge</p> <p>Enables NACK, always. If you write 1 to this field, the target rejects all requests to it, except for a common command code (CCC) broadcast. NACK = 1 must be used with caution because the controller may decide that the target is missing, if NACK is overused.</p> <p>0b - Always NACK disable<br/>1b - Always NACK enable</p>                                                    |
| 0<br>SLVENA   | <p>Target Enable</p> <p>Enables the target. If you write 0 to this field, the target ignores the I2C or I3C bus. If you write 1 to this field, the target can operate on the I2C or I3C bus.</p>                                                                                                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <p>You must not write 1 to this field before writing 1 to <a href="#">Target Configuration (SCONFIG)</a>, <a href="#">Target ID Part Number (SIDPARTNO)</a>, <a href="#">Target ID Extension (SIDEXT)</a>, and others because these registers affect the data to and from the controller. Target enable is configured just once before the bus comes up. If target enable is used at other times, see Hot-Join. In case of Hot-Join, <a href="#">SCAPABILITIES[IBI_MR_HJ]</a> must be 1 before writing 1 to SLVENA so that the chip does not see a Start or Stop condition incorrectly.</p> <p>0b - Disable<br/>1b - Enable</p> |

### 39.7.4 Target Status (SSTATUS)

#### Offset

| Register | Offset |
|----------|--------|
| SSTATUS  | 8h     |

#### Function

Indicates the sticky status for interrupts, states, and modes related to the bus. Not all fields of the register are used if the module only acts as a target. The fields are divided into current activity, interrupt maskable actions, and states and modes on the bus.

#### Diagram

| Bits  | 31       | 30       | 29     | 28          | 27       | 26     | 25       | 24     | 23 | 22     | 21    | 20       | 19       | 18        | 17        | 16          |
|-------|----------|----------|--------|-------------|----------|--------|----------|--------|----|--------|-------|----------|----------|-----------|-----------|-------------|
| R     | TIMECTRL | ACTSTATE | HJDIS  | 0           | MRDIS    | IBIDIS |          | 0      |    | EVDET  |       | 0        | EVEN T   | CHAN DLED | HDRM ATCH |             |
| W     |          |          |        |             |          |        |          |        |    |        |       |          | W1C      | W1C       | W1C       |             |
| Reset | 0        | 0        | 0      | 0           | 0        | 0      | 0        | 0      | 0  | 0      | 0     | 0        | 0        | 0         | 0         | 0           |
| Bits  | 15       | 14       | 13     | 12          | 11       | 10     | 9        | 8      | 7  | 6      | 5     | 4        | 3        | 2         | 1         | 0           |
| R     | ERRW ARN | CCC      | DACH G | TXNO TFU... | RX_ PEND | STOP   | MATC HED | STAR T | 0  | STHD R | STD A | STRE QWR | STRE QRD | STCC CH   | STMS G    | STNO TST... |
| W     |          | W1C      | W1C    |             |          | W1C    | W1C      | W1C    |    |        |       |          |          |           |           |             |
| Reset | 0        | 0        | 0      | 1           | 0        | 1      | 0        | 0      | 0  | 0      | 0     | 0        | 0        | 0         | 0         | 0           |

#### Fields

| Field             | Function                                                                                |
|-------------------|-----------------------------------------------------------------------------------------|
| 31-30<br>TIMECTRL | <p>Time Control</p> <p>Indicates whether time control is enabled, and in which mode</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field             | Function                                                                                                                                                                                                                                                                                                                                                 |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | 00b - NO_TIME_CONTROL. No time control is enabled<br>01b - SYNC_MODE. Synchronous mode is enabled<br>10b - ASYNC_MODE. Asynchronous standard mode (0 or 1) is enabled<br>11b - BOTHSYNCASYNC. Both Synchronous and Asynchronous modes are enabled                                                                                                        |
| 29-28<br>ACTSTATE | Activity State from Common Command Codes (CCC)<br>00b - NO_LATENCY. Normal bus operations<br>01b - LATENCY_1MS. 1 ms of latency<br>10b - LATENCY_100MS. 100 ms of latency<br>11b - LATENCY_10S. 10 seconds of latency                                                                                                                                    |
| 27<br>HJDIS       | Hot-Join Disabled<br>While Hot-Join is disabled, CTRL requests are not responded to.<br>0b - Hot-Join not disabled<br>1b - Hot-Join disabled                                                                                                                                                                                                             |
| 26<br>—           | Reserved                                                                                                                                                                                                                                                                                                                                                 |
| 25<br>MRDIS       | Controller Requests Are Disabled<br>While Controller Requests are disabled, CTRL requests are not responded to.<br>0b - Controller Requests not disabled<br>1b - Controller Requests disabled                                                                                                                                                            |
| 24<br>IBIDIS      | In-Band Interrupts Are Disabled<br>While In-Band Interrupts are disabled, CTRL requests are not responded to.<br>0b - In-Band Interrupts not disabled<br>1b - In-Band Interrupts disabled                                                                                                                                                                |
| 23-22<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                 |
| 21-20<br>EVDET    | Event Details<br>Current details of the last (SSTATUS[EVENT] = 1) or pending event.<br>00b - NONE. No event or no pending event<br>01b - NO_REQUEST. Request is not sent yet. Either there was no START yet, or is waiting for Bus-Available or Bus-Idle (HJ).<br>10b - NACKED. Not acknowledged (request sent and rejected). The module will try again. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | 11b - ACKED. Acknowledged (request sent and accepted), so done (unless the time control data is still being sent).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 19<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 18<br>EVENT    | <p>Event</p> <p>For a target, indicates that a pending In-Band Interrupt (IBI), Controller Request (CR), or Hot-Join (HJ) has been sent as requested. See the upper status register fields for details.</p> <p>EVENT only asserts when ACKed by a controller.</p> <p>0b - No event has occurred.</p> <p>1b - An IBI, CR, or HJ has occurred.</p>                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 17<br>CHANDLED | <p>Common Command Code Handled</p> <p>Indicates whether a CCC is being handled by the module. This field is a notification only, but it may result in updates to the SSTATUS register.</p> <p>0b - CCC handling not in progress.</p> <p>1b - CCC handling in progress.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 16<br>HDRMATCH | <p>High Data Rate Command Match</p> <p>Indicates whether HDR command matched the I3C Dynamic Address of this device. The HDR command is available as the first byte and RXPEND are set. The MSB of the command byte indicates whether it is a read or a write command. If the HDR command is a read, and there are to-bus bytes waiting, then the command is ACKed and the data is sent back. Otherwise, the HDR command is NACKed.</p> <p><b>NOTE</b><br/>When HDRMATCH is 1, ERRWARN should be checked, because the HPAR error may be encountered after signaling this HDR command. The parity is after the destination address and command.</p> <p>0b - HDR command did not match.</p> <p>1b - HDR command matched the I3C Dynamic Address of this device.</p> |
| 15<br>ERRWARN  | <p>Error Warning</p> <p>An error or warning has occurred, such as data underrun, data overrun, parity error, HDR-DDR CRC error, or other error or warning condition. See the <a href="#">Target Errors and Warnings (SERRWARN)</a>.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 14<br>CCC      | <p>Common Command Code</p> <p>Indicates whether a CCC has been received, and is not handled by the I3C module. There are 2 types of Common Command Codes:</p> <ul style="list-style-type: none"> <li>• Broadcast CCC. Corresponds with RXPEND, and the first byte is the CCC (command).</li> <li>• Direct CCC, which may never be directed to this device. If Direct CCC are directed to this device, then the TXSEND or RXPEND are triggered, and the RXPEND contains the command.</li> </ul>                                                                                                                                                                                                                                                                    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | <p>0b - No CCC received.</p> <p>1b - CCC received.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 13<br>DACHG     | <p>Dynamic Address Change</p> <p>Indicates occurrence of dynamic address (DA) change. Actual DA can be seen in the DYNADDR register. This field is also used when the MAP Auto feature is configured, changing one or more MAP items. See DYNADDR and MAPCTRLn. DYNAADDR for the main DA (0) indicates whether last change was due to Auto-MAP.</p> <p>0b - No DA change detected.</p> <p>1b - DA change detected. The target DA has been assigned, re-assigned, or reset (lost) and is now in the state of being valid or none.</p>                                    |
| 12<br>TXNOTFULL | <p>Transmit Buffer Is Not Full</p> <p>Indicates whether transmit buffer is not full. If DMA is enabled for transmitting, then it will also be signaled to provide more data.</p> <p>0b - Transmit buffer full</p> <p>1b - Transmit buffer not full. To-bus buffer or FIFO can accept more data to be transmitted. For all but External FIFO, this process uses <a href="#">SDATACTRL[TXTRIG]</a>, which defaults to not-full.</p>                                                                                                                                       |
| 11<br>RX_PEND   | <p>Received Message Pending</p> <p>Indicates when receiving a message from the controller that is not being handled by the I3C module (not a CCC message). Such messages are internally processed by the module. For all but External FIFO, this process uses <a href="#">SDATACTRL[RXTRIG]</a>, which defaults to not-empty. If DMA is enabled for receiving, then DMA is signaled as well. RX_PEND automatically becomes 0 if data is read (from FIFO and non-FIFO sources).</p> <p>0b - No received message is pending.</p> <p>1b - Received message is pending.</p> |
| 10<br>STOP      | <p>Stop</p> <p>Detects stopped state. The STNOTSTOP state also indicates when the module is in stop mode. A fast STOP/START combination may not trigger the STOP status. In that case, START is always set.</p> <p>0b - No STOP detected.</p> <p>1b - Stopped state detected. A STOP state was present on the bus since the bus was last cleared.</p>                                                                                                                                                                                                                   |
| 9<br>MATCHED    | <p>Matched</p> <p>0b - No header matched.</p> <p>1b - An incoming header matched the I3C Dynamic or I2C Static address of this device (if any) since the bus was last cleared.</p>                                                                                                                                                                                                                                                                                                                                                                                      |
| 8               | Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                              |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| START        | This field is not usually needed, but can be used for wake events.<br>0b - No START seen.<br>1b - A START or repeated START was seen after the START bit was last cleared.                                                                                                                                                            |
| 7<br>—       | Reserved                                                                                                                                                                                                                                                                                                                              |
| 6<br>STHDR   | Status High Data Rate<br>Indicates whether the I3C bus is in HDR-DDR mode, regardless of whether HDR mode is supported by I3C, and regardless of whether the message is intended for I3C or some other module.<br>0b - I3C bus not in HDR-DDR mode<br>1b - I3C bus in HDR-DDR mode                                                    |
| 5<br>STDAA   | Status Dynamic Address Assignment<br>Indicates whether the I3C bus is in Enter Dynamic Address Assignment (ENTDAA) mode, regardless of whether this bus target has a dynamic address.<br>0b - Not in ENTDAA mode<br>1b - In ENTDAA mode                                                                                               |
| 4<br>STREQWR | Status Request Write<br>Indicates whether the REQ in process is SDR write data from the controller to this bus target (or all targets), but not in ENTDAA mode.<br>See status high data rate (STHDR) for double data rate (DDR) handling.<br>0b - Not an SDR write<br>1b - SDR write data from the controller, but not in ENTDAA mode |
| 3<br>STREQRD | Status Request Read<br>Indicates whether the REQ in process is an SDR read from this target, or an in-band interrupt (IBI) is being pushed out.<br>See status high data rate (STHDR) for double data rate (DDR) handling.<br>0b - Not an SDR read<br>1b - SDR read from this target or an IBI is being pushed out                     |
| 2<br>STCCCH  | Status Common Command Code Handler<br>Indicates whether a CCC message is being handled automatically.<br>0b - No CCC message handled<br>1b - Handled automatically                                                                                                                                                                    |
| 1<br>STMSG   | Status Message                                                                                                                                                                                                                                                                                                                        |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                                                                                           |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | Indicates whether the bus target is busy (listening to the bus traffic or responding). If STNOTSTOP = 1, STMSG is 0 when a nonmatching address is seen, until the next repeated Start or Stop condition occurs.<br>0b - Idle<br>1b - Busy                                                                          |
| 0<br>STNOTSTOP | Status Not Stop<br>Indicates the status of the bus. If this field is 1, the bus is busy (has activity).<br>Other fields of this register may also be 1 when busy. STNOTSTOP can also become 1 after a TE0 or TE1 error, when the I3C module is waiting for an exit pattern.<br>0b - In Stop condition<br>1b - Busy |

### 39.7.5 Target Control (SCTRL)

#### Offset

| Register | Offset |
|----------|--------|
| SCTRL    | Ch     |

#### Function

Contains controls for the active use of the I3C bus (for example, event generation such as interrupts to the controller). Only if the module is configured to support various special operations for the target, this register is used to activate those operations. These events include IBI and GETSTATUS fields (except Protocol error, which is automatically set).

#### Diagram



## Fields

| Field             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24<br>VENDINFO | Vendor Information<br><br>Should be set to the Vendor Reserved field that the GETSTATUS CCC returns. The vendor information should be maintained by the application, because the controller reads this field. If VENDINFO is not configured, then the GETSTATUS field always returns 0.                                                                                                                                                      |
| 23-22<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 21-20<br>ACTSTATE | Activity State of Target<br><br>Should be set to the activity state of the target that the GETSTATUS CCC command returns as activity mode. The activity state should be maintained by the application, because the controller reads this field. If the activity state is not configured, then the GETSTATUS command always returns 0.                                                                                                        |
| 19-16<br>PENDINT  | Pending Interrupt<br><br>Should be set to the pending interrupt that the GETSTATUS CCC command returns. The pending interrupt should be maintained by the application, because the controller reads this field.<br><br>If PENDINT = 0 and <ul style="list-style-type: none"> <li>• If an IBI interrupt is pending, the GETSTATUS command returns 1.</li> <li>• If an IBI interrupt is not pending, the GETSTATUS field returns 0.</li> </ul> |
| 15-8<br>IBIDATA   | In-Band Interrupt Data<br><br>Data byte accompanying the IBI, if the module is enabled for IBI. If <a href="#">SCTRL[IBIDATA]</a> is enabled, then IBI is required.                                                                                                                                                                                                                                                                          |
| 7-4<br>—          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3<br>EXTDATA      | Extended Data<br><br>See <a href="#">IBIEXT1[MAX]</a> . If extended data is used with time control, the data follows the time information. <ul style="list-style-type: none"> <li>0b - Extended data disabled.</li> <li>1b - Extended data enabled. After IBIDATA is emitted, extended data is taken from IBIEXT1 and IBIEXT2 if configured.</li> </ul>                                                                                      |
| 2<br>—            | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 1-0<br>EVENT      | Event <ul style="list-style-type: none"> <li>• If EVENT is set to a nonzero value, it requests an event.</li> <li>• After the request, SSTATUS[EVENT] and SSTATUS[EVDET] show the status as it progresses.</li> <li>• After completion, the EVENT field automatically returns to 0.</li> <li>• After EVENT is a nonzero value, only 0 can be written to EVENT (to cancel) until the event processing is finished.</li> </ul>                 |

Table continues on the next page...

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <p>00b - NORMAL_MODE. If EVENT is set to 0 after it was a nonzero value and event processing has not yet started, event processing is canceled. If event processing has already started, event processing is not canceled.</p> <p>01b - IBI. Start pushing an IBI onto the I3C bus. If there is data associated with the IBI, the data is read from <a href="#">SCTRL[IBIDATA]</a>. If time control is enabled, this data includes any time-control-related bytes. Additionally, SCTRL[IBIDATA] bit 7 becomes 1 automatically (as is required for time control). The IBI interrupt occurs after the first (mandatory) IBIDATA, if any.</p> <p>10b - CONTROLLER_REQUEST. Start a Controller Request: the meaning depends on the Bus Characteristics Register (<a href="#">SIDEXT[BCR]</a>) configured in the I3C module.</p> <p>11b - HOT_JOIN_REQUEST. Start a Hot-Join request. A Hot-Join Request is used when the device is powered on after the I3C bus is already powered up. It is also used when the device is connected using hot-insertion methods (the device is powered up when it is physically inserted in the powered-up I3C bus). The HJ waits for Bus Idle, and SCTRL[EVENT] = HOT_JOIN_REQUEST must be set before the target enable (<a href="#">SCONFIG[SLVENA]</a>).</p> |

### 39.7.6 Target Interrupt Set (SINTSET)

#### Offset

| Register | Offset |
|----------|--------|
| SINTSET  | 10h    |

#### Function

Sets interrupt enables for select [Target Status \(SSTATUS\)](#) fields. Reading the SINTSET register returns the status of the interrupt enables.

- To activate an interrupt enable, write 1 to its corresponding field in this register (SINTSET).
- To disable an interrupt, write 1 to its corresponding field in the [Target Interrupt Clear \(SINTCLR\)](#) register. Writing 0 to the interrupt enable in this register (SINTSET) does not disable the interrupt.

The Interrupt registers allow the masking of interrupt sources. They also allow the checking of which interrupts have activated. The normal method is to enable an interrupt, and then once the interrupt occurs, clear the interrupt either by writing the SSTATUS register or by performing action on the corresponding data register. The interrupt is level-held, meaning the interrupt stays set until the cause is cleared by some method. The module prevents races; if a new event occurs, that new event is not lost.

- SINTSET sets interrupt enables for [Target Status \(SSTATUS\)](#) fields. Reading the SINTSET register returns the status of the interrupt enables.
- SINTCLR clears interrupt enables for SSTATUS fields.
- SINTMASKED returns the value of the SSTATUS fields ANDed with their interrupt enables.

**Diagram**

| Bits  | 31       | 30  | 29     | 28      | 27      | 26   | 25       | 24     | 23 | 22 | 21 | 20 | 19 | 18     | 17        | 16          |
|-------|----------|-----|--------|---------|---------|------|----------|--------|----|----|----|----|----|--------|-----------|-------------|
| R     |          |     |        |         | 0       |      |          |        |    |    |    |    | 0  | EVEN T | CHAN DLED | DDRM ATC... |
| W     |          |     |        |         |         |      |          |        |    |    |    |    |    |        |           |             |
| Reset | 0        | 0   | 0      | 0       | 0       | 0    | 0        | 0      | 0  | 0  | 0  | 0  | 0  | 0      | 0         | 0           |
| Bits  | 15       | 14  | 13     | 12      | 11      | 10   | 9        | 8      | 7  | 6  | 5  | 4  | 3  | 2      | 1         | 0           |
| R     | ERRW ARN | CCC | DACH G | TXSE ND | RXPE ND | STOP | MATC HED | STAR T |    |    |    |    | 0  |        |           |             |
| W     |          |     |        |         |         |      |          |        |    |    |    |    |    |        |           |             |
| Reset | 0        | 0   | 0      | 0       | 0       | 0    | 0        | 0      | 0  | 0  | 0  | 0  | 0  | 0      | 0         | 0           |

**Fields**

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-20            | Reserved                                                                                                                                                                                                                                                                                                                                                                |
| —                |                                                                                                                                                                                                                                                                                                                                                                         |
| 19               | Reserved                                                                                                                                                                                                                                                                                                                                                                |
| —                |                                                                                                                                                                                                                                                                                                                                                                         |
| 18<br>EVENT      | <p>Event Interrupt Enable</p> <p>Indicates, for a target, that a pending In-Band Interrupt (IBI), Controller Request (CR), or Hot-Join (HJ) has been sent as requested. See <a href="#">SSTATUS[EVDET]</a>. Used only if configured to support events.</p> <p>0b - Disable Event interrupt</p> <p>1b - Enable Event interrupt</p>                                       |
| 17<br>CHANLED    | <p>Common Command Code (CCC) Interrupt Enable</p> <p>Indicates whether a CCC is being handled by the module. SSTATUS shows new results. CHANLED can be used to track when Activity states and when masks on events (for example, IBIs) occur. Used for CCCs that are enabled.</p> <p>0b - Disable CCC Handled interrupt</p> <p>1b - Enable CCC Handled interrupt</p>    |
| 16<br>DDRMATCHED | <p>Double Data Rate Interrupt Enable</p> <p>Indicates when DDR matched for read or write command. Used only if HDR enabled.</p> <p>0b - Disable DDR interrupt</p> <p>1b - Enable DDR interrupt</p>                                                                                                                                                                      |
| 15<br>ERRWARN    | <p>Error or Warning Interrupt Enable</p> <p>Indicates that an error or warning has occurred, such as data underrun, data overrun, parity error, or HDR-DDR CRC error, or other error or warning condition. See the <a href="#">Target Errors and Warnings (SERRWARN)</a> register for details of the cause. Only available for errors that are configured features.</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | 0b - Disable error or warning interrupt<br>1b - Enable error or warning interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 14<br>CCC    | Common Command Code (CCC) Interrupt Enable<br>Indicates whether a CCC has been received, and is not handled by the I3C module. For CCCs not handled by the block, RXPEND also interrupts, and SSTATUS[STREQRD] indicates that it is a CCC sending a read request.<br>0b - Disable CCC interrupt<br>1b - Enable CCC interrupt                                                                                                                                                                                                                                   |
| 13<br>DACHG  | Dynamic Address Change Interrupt Enable<br>Interrupt on Dynamic address defined (SETDASA or ENTDAA) or lost (RSTDAA). See also <a href="#">Controller Dynamic Address (MDYNADDR) register</a> .<br>0b - Disable DA Change interrupt<br>1b - Enable DA Change interrupt                                                                                                                                                                                                                                                                                         |
| 12<br>TXSEND | Transmit Interrupt Enable<br>Indicates to-bus buffer or FIFO can accept more data to be transmitted. Interrupt when request data by controller (read). This interrupt occurs on the first request (header) as well as when ready for more. The application indicates whether the interrupt is for more data or END. If this interrupt is for a FIFO, it triggers on the Transmit emptiness trigger. If this interrupt is for DMA, then it indicates message end (DMA end or termination).<br>0b - Disable Transmit interrupt<br>1b - Enable Transmit interrupt |
| 11<br>RXPEND | Receive Interrupt Enable<br>Indicates when receiving a message from the controller that is not being handled by the block. For example, where data is consumed by hardware directly when it goes into the FIFO (excludes CCCs being handled automatically). If this interrupt is for a FIFO, it is a receive fullness trigger. If this interrupt is for DMA, then it indicates message end.<br>0b - Disable Receive interrupt<br>1b - Enable Receive interrupt                                                                                                 |
| 10<br>STOP   | Stop Interrupt Enable<br>Stopped state detected. A STOP state was present on the bus since the bus was last cleared. See <a href="#">SINTSET[START]</a> as the preferred interrupt when needed. This interrupt may not trigger for quick a STOP/START combination, because it relates to the state of being stopped.<br>0b - Disable STOP interrupt<br>1b - Enable STOP interrupt                                                                                                                                                                              |
| 9            | Match Interrupt Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field   | Function                                                                                                                                                                                                                                                                                                                                                                        |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MATCHED | <p>Incoming header matched the I3C Dynamic or I2C Static address of this device since the bus was last cleared. If configured and if no Dynamic Address set, this interrupt is also for matching a header on an I2C Static Address. See <a href="#">Controller Dynamic Address (MDYNADDR) register</a>.</p> <p>0b - Disable match interrupt<br/>1b - Enable match interrupt</p> |
| 8 START | <p>Start Interrupt Enable</p> <p>A START or repeated START (such as wakeup) was seen after the START bit was last cleared.</p> <p>See also <a href="#">SINTSET[STOP]</a>.</p> <p>0b - Disable START interrupt<br/>1b - Enable START interrupt</p>                                                                                                                               |
| 7-0 —   | Reserved                                                                                                                                                                                                                                                                                                                                                                        |

### 39.7.7 Target Interrupt Clear (SINTCLR)

#### Offset

| Register | Offset |
|----------|--------|
| SINTCLR  | 14h    |

#### Function

Clears interrupt enables for select [Target Status \(SSTATUS\) fields](#). To clear an interrupt enable, write 1 to the corresponding field in this register (SINTCLR). Writing 0 has no effect.

#### Diagram

| Bits  | 31       | 30  | 29     | 28      | 27      | 26   | 25       | 24     | 23 | 22 | 21 | 20 | 19 | 18     | 17        | 16          |
|-------|----------|-----|--------|---------|---------|------|----------|--------|----|----|----|----|----|--------|-----------|-------------|
| R     |          |     |        |         |         |      |          |        | 0  |    |    |    | 0  | EVEN T | CHAN DLED | DDRM ATC... |
| W     |          |     |        |         |         |      |          |        |    |    |    |    |    | W1C    | W1C       | W1C         |
| Reset | u        | u   | u      | u       | u       | u    | u        | u      | u  | u  | u  | u  | u  | u      | u         | u           |
| Bits  | 15       | 14  | 13     | 12      | 11      | 10   | 9        | 8      | 7  | 6  | 5  | 4  | 3  | 2      | 1         | 0           |
| R     | ERRW ARN | CCC | DACH G | TXSE ND | RXPE ND | STOP | MATC HED | STAR T |    |    |    |    | 0  |        |           |             |
| W     | W1C      | W1C | W1C    | W1C     | W1C     | W1C  | W1C      | W1C    |    |    |    |    |    |        |           |             |
| Reset | u        | u   | u      | u       | u       | u    | u        | u      | u  | u  | u  | u  | u  | u      | u         | u           |

**Fields**

| Field            | Function                          |
|------------------|-----------------------------------|
| 31-20<br>—       | Reserved                          |
| 19<br>—          | Reserved                          |
| 18<br>EVENT      | EVENT Interrupt Enable Clear      |
| 17<br>CHANDLED   | CHANDLED Interrupt Enable Clear   |
| 16<br>DDRMATCHED | DDRMATCHED Interrupt Enable Clear |
| 15<br>ERRWARN    | ERRWARN Interrupt Enable Clear    |
| 14<br>CCC        | CCC Interrupt Enable Clear        |
| 13<br>DACHG      | DACHG Interrupt Enable Clear      |
| 12<br>TXSEND     | TXSEND Interrupt Enable Clear     |
| 11<br>RXPEND     | RXPEND Interrupt Enable Clear     |
| 10<br>STOP       | STOP Interrupt Enable Clear       |
| 9<br>MATCHED     | MATCHED Interrupt Enable Clear    |
| 8<br>START       | START Interrupt Enable Clear      |
| 7-0<br>—         | Reserved                          |

### 39.7.8 Target Interrupt Mask (SINTMASKED)

#### Offset

| Register   | Offset |
|------------|--------|
| SINTMASKED | 18h    |

#### Function

Returns the status of enabled interrupts (the value of [Target Status \(SSTATUS\)](#) ANDed with the value of [Target Interrupt Set \(SINTSET\)](#) ).

#### Diagram

| Bits  | 31          | 30  | 29        | 28         | 27         | 26   | 25          | 24        | 23 | 22 | 21 | 20 | 19 | 18        | 17           | 16             |
|-------|-------------|-----|-----------|------------|------------|------|-------------|-----------|----|----|----|----|----|-----------|--------------|----------------|
| R     |             |     |           |            | 0          |      |             |           |    |    |    |    | 0  | EVEN<br>T | CHAN<br>DLED | DDRM<br>ATC... |
| W     |             |     |           |            |            |      |             |           |    |    |    |    |    |           |              |                |
| Reset | 0           | 0   | 0         | 0          | 0          | 0    | 0           | 0         | 0  | 0  | 0  | 0  | 0  | 0         | 0            | 0              |
| Bits  | 15          | 14  | 13        | 12         | 11         | 10   | 9           | 8         | 7  | 6  | 5  | 4  | 3  | 2         | 1            | 0              |
| R     | ERRW<br>ARN | CCC | DACH<br>G | TXSE<br>ND | RXPE<br>ND | STOP | MATC<br>HED | STAR<br>T |    |    |    |    | 0  |           |              |                |
| W     |             |     |           |            |            |      |             |           |    |    |    |    |    |           |              |                |
| Reset | 0           | 0   | 0         | 0          | 0          | 0    | 0           | 0         | 0  | 0  | 0  | 0  | 0  | 0         | 0            | 0              |

#### Fields

| Field      | Function                  |
|------------|---------------------------|
| 31-20      | Reserved                  |
| —          |                           |
| 19         | Reserved                  |
| —          |                           |
| 18         | EVENT Interrupt Mask      |
| EVENT      |                           |
| 17         | CHANLED Interrupt Mask    |
| CHANLED    |                           |
| 16         | DDRMATCHED Interrupt Mask |
| DDRMATCHED |                           |
| 15         | ERRWARN Interrupt Mask    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function               |
|--------------|------------------------|
| ERRWARN      |                        |
| 14<br>CCC    | CCC Interrupt Mask     |
| 13<br>DACHG  | DACHG Interrupt Mask   |
| 12<br>TXSEND | TXSEND Interrupt Mask  |
| 11<br>RXPEND | RXPEND Interrupt Mask  |
| 10<br>STOP   | STOP Interrupt Mask    |
| 9<br>MATCHED | MATCHED Interrupt Mask |
| 8<br>START   | START interrupt mask   |
| 7-0<br>—     | Reserved               |

### 39.7.9 Target Errors and Warnings (SERRWARN)

#### Offset

| Register | Offset |
|----------|--------|
| SERRWARN | 1Ch    |

#### Function

Contains errors and warnings from I3C and I2C protocols, which includes internal issues such as overrun and underrun, detected errors and conditions like parity errors, CRC errors, and read terminations by the controller. Related to [SSTATUS\[ERRWARN\]](#) and [SINTSET\[ERRWARN\]](#) interrupt.

**Diagram**

| Bits  | 31 | 30 | 29 | 28   | 27   | 26   | 25   | 24 | 23 | 22 | 21           | 20   | 19           | 18   | 17         | 16        |
|-------|----|----|----|------|------|------|------|----|----|----|--------------|------|--------------|------|------------|-----------|
| R     |    |    |    |      | 0    |      |      |    | 0  |    | 0            |      | 0            | 0    | OWRI<br>TE | OREA<br>D |
| W     |    |    |    |      |      |      |      |    |    |    |              |      |              |      | W1C        | W1C       |
| Reset | 0  | 0  | 0  | 0    | 0    | 0    | 0    | 0  | 0  | 0  | 0            | 0    | 0            | 0    | 0          | 0         |
| Bits  | 15 | 14 | 13 | 12   | 11   | 10   | 9    | 8  | 7  | 6  | 5            | 4    | 3            | 2    | 1          | 0         |
| R     | 0  | 0  | 0  | S0S1 | HCRC | HPAR | SPAR |    | 0  |    | INVST<br>ART | TERM | URUN<br>NACK | URUN | ORUN       |           |
| W     |    |    |    | W1C  | W1C  | W1C  | W1C  |    |    |    | W1C          | W1C  | W1C          | W1C  | W1C        |           |
| Reset | 0  | 0  | 0  | 0    | 0    | 0    | 0    | 0  | 0  | 0  | 0            | 0    | 0            | 0    | 0          | 0         |

**Fields**

| Field        | Function                                                                                                                                                                                                                                                                                                                                                             |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-22<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                             |
| 21<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                             |
| 20-18<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                             |
| 17<br>OWRITE | <p>Over-write Error</p> <p>Indicates that the <a href="#">Target Write Data Byte (SWDATAB)</a> or <a href="#">Target Write Data Byte End (SWDATABE)</a> register was written when full.</p> <p>0b - No Overwrite error<br/>1b - Overwrite error</p>                                                                                                                  |
| 16<br>OREAD  | <p>Over-read Error</p> <p>Indicates that the <a href="#">Target Read Data Byte (SRDATAB)</a> register was read for more bytes than were available by the application. This error also indicates over-read errors for the <a href="#">Target Read Data Halfword (SRDATAH)</a> register, if it is enabled.</p> <p>0b - No Over-read error<br/>1b - Over-read error</p> |
| 15-14<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                             |
| 13<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 11<br>S0S1    | <p>TE0 or TE1 Error</p> <p>Indicates when an TE0 or TE1 error has occurred and the target is locked and waiting for an HDR Exit Pattern. Writing 1 to S0S1 causes the module to release the lock, but this method should be used with great care. S0S1 becomes 0 automatically when an Exit Pattern is detected, so writing 1 to S0S1 must be used under controlled circumstances to avoid problems. Before starting to operate normally after this error, the module waits for a START (or repeated START) or STOP.</p> <p>0b - No TE0 or TE1 error<br/>1b - TE0 or TE1 error</p> |
| 10<br>HCRC    | <p>HDR-DDR CRC Error</p> <p>Indicates when an HDR-DDR Cyclic Redundancy Check (CRC) error on a message from the controller occurs. Causes include an HDR Restart and an Exit being issued before an HDR-DDR message from controller has finished. This error calls into question the data from the entire DDR command frame.</p> <p>0b - No HDR-DDR CRC error<br/>1b - HDR-DDR CRC error</p>                                                                                                                                                                                       |
| 9<br>HPAR     | <p>HDR Parity Error</p> <p>Indicates when HDR Parity error or framing error on a message from the controller occurs. The corresponding command or data that has the error is usually in the Rx buffer, which can be read using the <a href="#">Target Read Data Byte (SRDATAB)</a> register.</p> <p>0b - No HDR Parity error<br/>1b - HDR Parity error</p>                                                                                                                                                                                                                         |
| 8<br>SPAR     | <p>SDR Parity Error</p> <p>Indicates when an SDR Parity error on a message from the controller occurs. This error also sets the GETSTATUS Protocol Error sticky bit (which becomes 0 after a GETSTATUS read).</p> <p>For read operations, this field becomes 1 when a Read Abort (timeout) occurs due to the controller not driving clock for more than 100 µs during an SDR Read.</p> <p>0b - No SDR Parity error<br/>1b - SDR Parity error</p>                                                                                                                                   |
| 7-5<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 4<br>INVSTART | <p>Invalid Start Error</p> <p>Indicates an invalid condition with SCL falling before SDA falls, so there is no start.</p> <p>0b - No invalid start error<br/>1b - Invalid start error</p>                                                                                                                                                                                                                                                                                                                                                                                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                     |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3<br>TERM     | <p>Terminated Error</p> <p>Indicates when the controller terminates a read from a target when an END is not set (on the same read or the previous read).</p> <p>0b - No terminated error<br/>1b - Terminated error</p>                                                                       |
| 2<br>URUNNACK | <p>Underrun and Not Acknowledged (NACKED) Error</p> <p>Indicates when the internal to-bus buffer/FIFO is underrun in the read header and so the module NACKED the header.</p> <p>0b - No underrun and not acknowledged error<br/>1b - Underrun and not acknowledged error</p>                |
| 1<br>URUN     | <p>Underrun Error</p> <p>Indicates when the internal to-bus buffer/FIFO is underrun during data read (the application is not providing the data fast enough). The END bit or register should be used if the read was the last one.</p> <p>0b - No underrun error<br/>1b - Underrun error</p> |
| 0<br>ORUN     | <p>Overrun Error</p> <p>Indicates when the internal from-bus buffer or FIFO is overrun (too many characters are arriving and cannot be processed by the user application fast enough).</p> <p>0b - No overrun error<br/>1b - Overrun error</p>                                               |

### 39.7.10 Target DMA Control (SDMACTRL)

#### Offset

| Register | Offset |
|----------|--------|
| SDMACTRL | 20h    |

#### Function

Allows DMA to be used for inbound and outbound messages. This register is limited in value for target use because the target must be reactive. Two common use models are:

- To avoid an overrun in from-bus collection. **SCONFIG[MATCHSS]** becomes 1, then the processor enables the interrupts for START and STOP and enables the DMA to collect the data. The START or STOP interrupt only occurs after a message is directed to the target (MATCHED is 1). The DMA copied data can then be examined.

#### NOTE

Do not enable DMA after a transaction starts. To avoid a RX FIFO overrun, DMA must be enabled only while enabling the target and interrupts.

- To perform larger reads from the to-bus. I3C and I2C reads are preceded by a write that indicates what will be read (or in response to an IBI from the target). Because of this process, the DMA can be used to push through the data.
  - For I3C, the last value must be managed by the processor, unless the DMA moves wider words and is able to write 1 to the END field. These values are 16-bit values when in byte mode or 32-bit values when in half-word mode.
  - For I2C, the last value is determined by the controller, so the DMA may end early or may run out when the controller expects more values.

### Diagram

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

### Fields

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7-6<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 5-4<br>DMAWIDTH | Width of DMA Operations<br>Indicates the width of DMA operations, if configured to allow half-word data access.<br>00b,01b - Byte<br>10b - Half word (16 bits). This value ensures that two bytes are available in the FIFO.<br>11b - Reserved                                                                                                                                                                                                                                                                                                                                                       |
| 3-2<br>DMATB    | DMA Write (To-bus) Trigger<br>Enables DMA writes. If enabled with 1 or 2, DMATB starts a request DMA on a transmit trigger (see <a href="#">Target Data Control (SDATACTRL)</a> ). DMATB requests until full, unless the DMA is set up as a trigger.<br>DMATB becomes 0 when <a href="#">MSTATUS[ERRWARN]</a> .<br>00b - DMA not used<br>01b - DMA enabled for one frame (ended by DMA or terminated). DMATB automatically becomes 0 after a STOP or START. See <a href="#">SCONFIG[MATCHSS]</a> .<br>10b - DMA enabled until turned off. This value must only be used with Controller Message mode. |

Table continues on the next page...

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | 11b - Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1-0<br>DMAFB | <p>DMA Read (From-bus) Trigger<br/>Enables DMA reads. If enabled with 1 or 2, DMAFB requests DMA on receive trigger (see <a href="#">SDATACTRL</a>). It requests until empty unless the DMA is set up as a trigger.<br/>DMAFB becomes 0 when <a href="#">SSTATUS[ERRWARN]</a> becomes 1.</p> <p><b>NOTE</b><br/>Do not enable DMA after a transaction starts. It must be enabled only while enabling the target and interrupts, to avoid any kind of RX FIFO overrun.</p> <p>00b - DMA not used<br/>01b - DMA is enabled for one frame. Automatically becomes 0 on STOP or repeated START. See <a href="#">SCONFIG[MATCHSS]</a>.<br/>10b - DMA enabled until turned off<br/>11b - Reserved</p> |

### 39.7.11 Target Data Control (SDATACTRL)

#### Offset

| Register  | Offset |
|-----------|--------|
| SDATACTRL | 2Ch    |

#### Function

Assists in data control when no FIFO is used. Also assists in data control of FIFO when the FIFO is available (regardless of size) allowing some control over the FIFO behavior. This register allows control of when to interrupt based on fullness or emptiness of a buffer or FIFO. It also controls behavior related to width, when the buffer or FIFO is not one byte wide.

#### Diagram

| Bits  | 31                 | 30                | 29 | 28             | 27            | 26 | 25 | 24            | 23 | 22             | 21                | 20                 | 19                 | 18 | 17 | 16 |
|-------|--------------------|-------------------|----|----------------|---------------|----|----|---------------|----|----------------|-------------------|--------------------|--------------------|----|----|----|
| R     | <b>RXEM</b><br>PTY | <b>TXFUL</b><br>L | 0  | <b>RXCOUNT</b> |               |    |    | 0             | 0  | <b>TXCOUNT</b> |                   |                    |                    |    |    |    |
| W     |                    |                   |    |                |               |    |    |               |    |                |                   |                    |                    |    |    |    |
| Reset | 1                  | 0                 | 0  | 0              | 0             | 0  | 0  | 0             | 0  | 0              | 0                 | 0                  | 0                  | 0  | 0  | 0  |
| Bits  | 15                 | 14                | 13 | 12             | 11            | 10 | 9  | 8             | 7  | 6              | 5                 | 4                  | 3                  | 2  | 1  | 0  |
| R     | 0                  |                   |    |                | <b>RXTRIG</b> |    |    | <b>TXTRIG</b> |    |                | <b>UNLO</b><br>CK | <b>FLUS</b><br>HFB | <b>FLUS</b><br>HTB |    |    |    |
| W     |                    |                   |    |                |               |    |    |               |    |                |                   |                    |                    |    |    |    |
| Reset | 0                  | 0                 | 0  | 0              | 0             | 0  | 0  | 0             | 0  | 0              | 1                 | 1                  | 0                  | 0  | 0  | 0  |

**Fields**

| Field            | Function                                                                                                                                                                                                                                                                                   |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>RXEMPTY    | Receive Is Empty<br>0b - Not empty<br>1b - Empty                                                                                                                                                                                                                                           |
| 30<br>TXFULL     | Transmit Is Full<br>0b - Not full<br>1b - Full                                                                                                                                                                                                                                             |
| 29<br>—          | Reserved                                                                                                                                                                                                                                                                                   |
| 28-24<br>RXCOUNT | Count of Bytes in Receive                                                                                                                                                                                                                                                                  |
| 23-22<br>—       | Reserved                                                                                                                                                                                                                                                                                   |
| 21<br>—          | Reserved                                                                                                                                                                                                                                                                                   |
| 20-16<br>TXCOUNT | Count of Bytes in Transmit                                                                                                                                                                                                                                                                 |
| 15-8<br>—        | Reserved                                                                                                                                                                                                                                                                                   |
| 7-6<br>RXTRIG    | Receive Trigger Level<br>Indicates trigger level for Receive fullness when using a FIFO. Affects RXPEND interrupt.<br>00b - Trigger when not empty<br>01b - Trigger when 1/4 or more full<br>10b - Trigger when 1/2 or more full<br>11b - Trigger when 3/4 or more full                    |
| 5-4<br>TXTRIG    | Transmit Trigger Level<br>Indicates trigger level for Transmit emptiness when using a FIFO. Affects TXNOTFULL interrupt.<br>00b - Trigger when empty<br>01b - Trigger when 1/4 full or less<br>10b - Trigger when 1/2 full or less<br>11b - Default. Trigger when 1 less than full or less |
| 3                | Unlock                                                                                                                                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                         |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| UNLOCK       | UNLOCK must be 1 in the same cycle while writing to TXTRIG or RXTRIG.<br>0b - RXTRIG and TXTRIG fields cannot be changed on a write.<br>1b - RXTRIG and TXTRIG fields can be changed on a write. |
| 2<br>—       | Reserved                                                                                                                                                                                         |
| 1<br>FLUSHFB | Flush the From-bus Buffer or FIFO<br>Not normally used.                                                                                                                                          |
| 0<br>FLUSHTB | Flush the To-bus Buffer or FIFO<br>Used when the controller terminates a to-bus (read) message prematurely.                                                                                      |

### 39.7.12 Target Write Data Byte (SWDATAB)

#### Offset

| Register | Offset |
|----------|--------|
| SWDATAB  | 30h    |

#### Function

Allows writing a byte to the bus (to controller) unless an external FIFO is used. Writing a byte requires a byte plus an end-of-data (last) marker bit. A byte should not be written unless there is room, indicated by [SSTATUS\[TXNOTFULL\]](#) = 1.

#### Diagram

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

**Fields**

| Field          | Function                                                                                                                                                                                                                                                                                                                                     |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-17<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                     |
| 16<br>END ALSO | <p>End Also</p> <p>This field is required for I3C, but is optional for I2C.</p> <p>For HDR-DDR, the byte with the END ALSO must be an even byte (second, fourth, sixth, and so on) because DDR uses byte-pairs.</p> <p>0b - Not the end. There are more bytes in the message.<br/>1b - End. This bit marks the last byte of the message.</p> |
| 15-9<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                     |
| 8<br>END       | <p>End</p> <p>This field is required for I3C, but is optional for I2C.</p> <p>For HDR-DDR, the byte with the END must be an even byte (second, fourth, sixth, and so on) because DDR uses byte-pairs.</p> <p>0b - Not the end. There are more bytes in the message.<br/>1b - End. This bit marks the last byte of the message.</p>           |
| 7-0<br>DATA    | <p>Data</p> <p>Data byte to send to the controller</p>                                                                                                                                                                                                                                                                                       |

**39.7.13 Target Write Data Byte End (SWDATABE)****Offset**

| Register | Offset |
|----------|--------|
| SWDATABE | 34h    |

**Function**

Allows writing a byte to the bus (to controller) unless an external FIFO is used. Unlike SWDATAB, writing a byte only requires the byte itself, and is marked as end-of-data (last byte). A byte should not be written unless there is room, indicated by **SSTATUS[TXNOTFULL]** = 1.

For HDR-DDR, the byte with the END must be an even byte (second, fourth, sixth, and so on) because DDR uses byte-pairs.

**Diagram**

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

**Fields**

| Field | Function                                |
|-------|-----------------------------------------|
| 31-8  | Reserved                                |
| —     |                                         |
| 7-0   | Data                                    |
| DATA  | The data byte to send to the controller |

**39.7.14 Target Write Data Half-word (SWDATAH)****Offset**

| Register | Offset |
|----------|--------|
| SWDATAH  | 38h    |

**Function**

Allows writing a half-word (pair of bytes) to the bus unless an external FIFO is used. Sends the low byte followed by the high byte. The 16th bit marks the end; that is, the last byte of the half-word is the end.

An end-of-data (last) marker bit is allowed (or must be 0). A half-word should not be written unless there is room for both, as indicated by the use of Transmit FIFO level trigger or [SDATACTRL\[TXCOUNT\]](#).

**Diagram**

| Bits  | 31 | 30 | 29 | 28 | 27    | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19    | 18 | 17 | 16  |
|-------|----|----|----|----|-------|----|----|----|----|----|----|----|-------|----|----|-----|
| R     |    |    |    |    |       |    |    |    | 0  |    |    |    |       |    |    |     |
| W     |    |    |    |    |       |    |    |    |    |    |    |    |       |    |    | END |
| Reset | u  | u  | u  | u  | u     | u  | u  | u  | u  | u  | u  | u  | u     | u  | u  | u   |
| Bits  | 15 | 14 | 13 | 12 | 11    | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3     | 2  | 1  | 0   |
| R     |    |    |    |    |       |    |    |    |    |    |    |    |       |    |    |     |
| W     |    |    |    |    | DATA1 |    |    |    |    |    |    |    | DATA0 |    |    |     |
| Reset | u  | u  | u  | u  | u     | u  | u  | u  | u  | u  | u  | u  | u     | u  | u  | u   |

**Fields**

| Field | Function                                                                                                                                                                                                                                                                                                                                                  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-17 | Reserved                                                                                                                                                                                                                                                                                                                                                  |
| —     |                                                                                                                                                                                                                                                                                                                                                           |
| 16    | End of message                                                                                                                                                                                                                                                                                                                                            |
| END   | This field always marks DATA1 as the end. This field is required for I3C, but is optional for I2C.<br><br>For HDR-DDR, the byte with the END must be an even byte (second, fourth, sixth, and so on) because DDR uses byte-pairs.<br><br>0b - Not the end. There are more bytes in the message.<br>1b - End. This bit marks the last byte of the message. |
| 15-8  | Data 1                                                                                                                                                                                                                                                                                                                                                    |
| DATA1 | The second byte to send to the controller                                                                                                                                                                                                                                                                                                                 |
| 7-0   | Data 0                                                                                                                                                                                                                                                                                                                                                    |
| DATA0 | The first byte to send to the controller                                                                                                                                                                                                                                                                                                                  |

**39.7.15 Target Write Data Half-word End (SWDATAHE)****Offset**

| Register | Offset |
|----------|--------|
| SWDATAHE | 3Ch    |

**Function**

Allows writing a half word of data, which is the end (the last byte of the half word is the end). Writes the half word (byte pair) just like [Target Write Data Half-word \(SWDATAH\)](#), but marks the second byte as end-of-data (last byte).

For HDR-DDR, the byte with the END must be an even (second, fourth, sixth, and so on) because DDR uses byte-pairs.

A half-word should not be written unless there is room for both, as indicated by the use of Transmit FIFO level trigger or [SDATACTRL\[TXCOUNT\]](#).

### Diagram

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

### Fields

| Field | Function                                  |
|-------|-------------------------------------------|
| 31-16 | Reserved                                  |
| —     |                                           |
| 15-8  | Data 1                                    |
| DATA1 | The second byte to send to the controller |
| 7-0   | Data 0                                    |
| DATA0 | The first byte to send to the controller  |

### 39.7.16 Target Read Data Byte (SRDATAB)

#### Offset

| Register | Offset |
|----------|--------|
| SRDATAB  | 40h    |

#### Function

Allows reading a byte from the bus (controller). A byte should not be read unless there is data waiting, as indicated by [SSTATUS\[RX\\_PEND\] = 1](#).

**Diagram**

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

**Fields**

| Field | Function                      |
|-------|-------------------------------|
| 31-8  | Reserved                      |
| —     |                               |
| 7-0   | Data 0                        |
| DATA0 | Byte read from the controller |

**39.7.17 Target Read Data Halfword (SRDATAH)****Offset**

| Register | Offset |
|----------|--------|
| SRDATAH  | 48h    |

**Function**

Allows reading a halfword (byte pair) written by the target after an SDR Read or DAA or DDR. This register is only used when using [Controller Control \(MCTRL\)](#) to start the message. If MWMSG\_SDR or MWMSG\_DDR is used to start a message, that interface must be used exclusively. A half word should not be read unless there are at least two bytes of data waiting, as indicated the Receive FIFO level trigger or [SDATACTRL\[RXCOUNT\]](#).

**Diagram**

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

**Fields**

| Field       | Function                             |
|-------------|--------------------------------------|
| 31-16<br>—  | Reserved                             |
| 15-8<br>MSB | The second byte read from the target |
| 7-0<br>LSB  | The first byte read from the target  |

**39.7.18 Target Write Data Byte (SWDATAB1)****Offset**

| Register | Offset |
|----------|--------|
| SWDATAB1 | 54h    |

**Function**

Allows writing a single byte to the bus (to controller) such that only bits 7:0 are used. Intended for use by DMAs, which do not format the upper part of the APB word.

A byte should not be written unless there is room, as indicated by SSTATUS[TXNOTFULL] = 1.

**Diagram**

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

**Fields**

| Field | Function                    |
|-------|-----------------------------|
| 31-8  | Reserved                    |
| —     |                             |
| 7-0   | Data                        |
| DATA  | Byte to send to controller. |

**39.7.19 Target Write Data Halfword (SWDATAH1)****Offset**

| Register | Offset |
|----------|--------|
| SWDATAH1 | 54h    |

**Function**

SWDATAH1 shares the same address as SWDATAB1. SDMACTRL[DMAWIDTH] determines which one is set.

SWDATAH1 allows writing a single byte pair (halfword) to the bus (to controller) such that only bits 15:0 are used. Intended for use by DMAs, which do not format the upper part of the APB word.

A halfword should not be written unless there is room, as indicated by SSTATUS[TXNOTFULL] = 1.

**Diagram**

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

**Fields**

| Field | Function                                    |
|-------|---------------------------------------------|
| 31-16 | Reserved                                    |
| —     |                                             |
| 15-0  | Data                                        |
| DATA  | Byte pair (halfword) to send to controller. |

**39.7.20 Target Capabilities 2 (SCAPABILITIES2)****Offset**

| Register       | Offset |
|----------------|--------|
| SCAPABILITIES2 | 5Ch    |

**Function**

Indicates which features are available and supported in this module, including controller and target capabilities, HDR modes, and others.

**Diagram**

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25          | 24     | 23        | 22           | 21         | 20         | 19    | 18         | 17 | 16 |
|-------|----|----|----|----|----|----|-------------|--------|-----------|--------------|------------|------------|-------|------------|----|----|
| R     |    |    |    |    | 0  |    |             |        | SSTW<br>R | SSTS<br>UB   | AASA       | 0          | GROUP | SLVR<br>ST | 0  |    |
| W     |    |    |    |    |    |    |             |        |           |              |            |            |       |            |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0           | 0      | 0         | 0            | 0          | 0          | 0     | 0          | 0  | 0  |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9           | 8      | 7         | 6            | 5          | 4          | 3     | 2          | 1  | 0  |
| R     |    |    |    |    | 0  |    | IBIXR<br>EG | IBIEXT | 0         | I2CDE<br>VID | I2CRS<br>T | I2C10<br>B |       | MAPCNT     |    |    |
| W     |    |    |    |    |    |    |             |        |           |              |            |            |       |            |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 1           | 1      | 0         | 0            | 0          | 0          | 0     | 0          | 0  | 0  |

**Fields**

| Field          | Function                                                                                                                                                                                                                                                                      |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24<br>—     | Reserved                                                                                                                                                                                                                                                                      |
| 23<br>SSTWR    | Target-Target(s)-Tunnel Write Capable<br>0b - Not write capable<br>1b - Write capable                                                                                                                                                                                         |
| 22<br>SSTSUB   | Target-Target(s)-Tunnel Subscriber Capable<br>0b - Not subscriber capable<br>1b - Subscriber capable                                                                                                                                                                          |
| 21<br>AASA     | Supports SETAASA<br>Supports the Set Static Address as Dynamic Address CCC feature<br>0b - Does not support SETAASA<br>1b - Supports SETAASA                                                                                                                                  |
| 20<br>—        | Reserved                                                                                                                                                                                                                                                                      |
| 19-18<br>GROUP | Group<br>Indicates whether v1.1 Group addressing is supported. Groups use mapping, so MAPCNT must be the same or greater than GROUP.<br>00b - Does not supports v1.1 Group addressing<br>01b - Supports one group<br>10b - Supports two groups<br>11b - Supports three groups |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                         |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17<br>SLVRST  | Target Reset<br>Indicates whether v1.1 Target Reset is supported<br>0b - Does not support Target Reset<br>1b - Supports Target Reset                                                                                                                                                                                                             |
| 16<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                         |
| 15-10<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                         |
| 9<br>IBIXREG  | In-Band Interrupt Extended Register<br>Indicates whether the <a href="#">Extended IBI Data 1 (IBIEXT1)</a> register is available. The <a href="#">Extended IBI Data 2 (IBIEXT2)</a> register is available if <a href="#">IBIEXT1[MAX]</a> > 3.<br>0b - Does not support extended registers for IBIs<br>1b - Supports extended registers for IBIs |
| 8<br>IBIEXT   | In-Band Interrupt EXTDATA<br>Supports <a href="#">SCTRL[EXTDATA]</a> to allow data beyond the mandatory data byte (MDB) for IBIs.<br>0b - Does not support IBIEXT<br>1b - Supports IBIEXT                                                                                                                                                        |
| 7<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                         |
| 6<br>I2CDEVID | I2C Device ID<br>Indicates whether I2C Device ID is supported<br>0b - Does not support I2C device ID<br>1b - Supports I2C device ID                                                                                                                                                                                                              |
| 5<br>I2CRST   | I2C Software Reset<br>Is 1 if I2C Software Reset is supported<br>0b - Does not support I2C software reset<br>1b - Supports I2C software reset                                                                                                                                                                                                    |
| 4<br>I2C10B   | I2C 10-bit Address<br>Allows 10-bit I2C address in MAP 1. If this field is 1, MAPCNT must be 1 or greater.<br>0b - Does not support 10-bit I2C address<br>1b - Supports 10-bit I2C address                                                                                                                                                       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field  | Function                                                                                                                                                             |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3-0    | Map Count                                                                                                                                                            |
| MAPCNT | Indicates how many maps are allowed. If there is no mapping, this field is 0. ( DYNADDR used to add more Static and/or Dynamic addresses to act as virtual targets.) |

### 39.7.21 Target Capabilities (SCAPABILITIES)

#### Offset

| Register      | Offset |
|---------------|--------|
| SCAPABILITIES | 60h    |

#### Function

Indicates which features are available and supported in this module, including controller and/or target capabilities, HDR modes, and others.

#### Diagram

| Bits  | 31       | 30  | 29     | 28    | 27     | 26 | 25      | 24 | 23    | 22           | 21 | 20        | 19 | 18 | 17 | 16 |
|-------|----------|-----|--------|-------|--------|----|---------|----|-------|--------------|----|-----------|----|----|----|----|
| R     | DMA      | INT | FIFORX |       | FIFOTX |    | EXTFIFO |    | 0     | TIMEC<br>TRL |    | IBI_MR_HJ |    |    |    |    |
| W     |          |     |        |       |        |    |         |    |       |              |    |           |    |    |    |    |
| Reset | 1        | 1   | 1      | 0     | 1      | 0  | 0       | 0  | 0     | 0            | 1  | 1         | 1  | 1  | 1  | 1  |
| Bits  | 15       | 14  | 13     | 12    | 11     | 10 | 9       | 8  | 7     | 6            | 5  | 4         | 3  | 2  | 1  | 0  |
| R     | CCHANDLE |     |        | SADDR | MASTER | 0  | HDRSUPP |    | IDREG |              |    | IDENA     |    |    |    |    |
| W     |          |     |        |       |        |    |         |    |       |              |    |           |    |    |    |    |
| Reset | 1        | 1   | 1      | 1     | 1      | 1  | 1       | 0  | 0     | 1            | 1  | 1         | 0  | 0  | 0  | 0  |

#### Fields

| Field | Function                                                                   |
|-------|----------------------------------------------------------------------------|
| 31    | Direct Memory Access                                                       |
| DMA   | Indicates whether DMA is supported<br>0b - Not supported<br>1b - Supported |
| 30    | Interrupts                                                                 |
| INT   | Indicates whether interrupts are supported                                 |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                                                                                                                                                               |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | 0b - Not supported<br>1b - Supported                                                                                                                                                                                                                                                                                                                                   |
| 29-28<br>FIFORX  | FIFO Receive<br>Indicates size of Receive (from-bus) FIFO.<br><div style="text-align: center;"> <b>NOTE</b><br/>           Target and Controller use the same receive FIFO, so size is the same for Controller receive FIFO as well.         </div> FIFO size of SDR and HDR-DDR is in bytes.<br>00b - Two or three<br>01b - Four<br>10b - Eight<br>11b - 16 or larger |
| 27-26<br>FIFOTX  | FIFO Transmit<br>Indicates size of Transmit (to-bus) FIFO.<br><div style="text-align: center;"> <b>NOTE</b><br/>           Target and Controller use the same transmit FIFO, so size is the same for Controller transmit FIFO as well.         </div> FIFO size of SDR and HDR-DDR is in bytes.<br>00b - Two<br>01b - Four<br>10b - Eight<br>11b - 16 or larger        |
| 25-23<br>EXTFIFO | External FIFO<br>Indicates whether External FIFOs are enabled. If External FIFOs are not enabled, then check FIFOTX and FIFORX for the internal FIFO.<br>000b - No external FIFO is available<br>001b - Standard available or free external FIFO<br>010b - Request track external FIFO<br>All other values are reserved.                                               |
| 22<br>—          | Reserved                                                                                                                                                                                                                                                                                                                                                               |
| 21               | Time Control<br>Specifies whether any time-control type is supported.                                                                                                                                                                                                                                                                                                  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field              | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TIMECTRL           | <p>0b - No time control enabled</p> <p>1b - At least one time-control type supported</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 20-16<br>IBI_MR_HJ | <p>In-Band Interrupts, Controller Requests, Hot-Join Events</p> <p>Indicates which events (IBI, CR, and HJ) are allowed. For example, if this field is 00011b, IBI (bit 0) and IBI_HAS_DATA (bit 1) functionality are both enabled.</p> <ul style="list-style-type: none"> <li>0_0000b - Application cannot generate IBI, CR, or HJ.</li> <li>1_xxxxb - Application can use SCONFIG[BAMATCH] for bus-available timing.</li> <li>x_1xxx - Application can generate a Hot-Join event.</li> <li>x_x1xx - Application can generate a Controller Request for a secondary controller.</li> <li>x_xx1xb - When bit 0 = 1, the IBI has data from the SCTRL register.</li> <li>x_xxx1b - Application can generate an IBI.</li> </ul> |
| 15-12<br>CCCHANDLE | <p>Common Command Codes Handling</p> <p>Indicates who manages CCC between I3C module and the user application.</p> <ul style="list-style-type: none"> <li>0000b - All handling features below are disabled.</li> <li>1xxx - GETSTATUS CCC returns SCTRL[VENDINFO] value.</li> <li>x1xx - GETSTATUS CCC returns SCTRL[PENDINT] and SCTRL[ACTSTATE] values.</li> <li>xx1xb - The block manages maximum read and write lengths, and max data speed.</li> <li>xxx1b - The block (I3C module) manages events, activities, status, HDR, and if enabled for it, ID and static-address-related items.</li> </ul>                                                                                                                    |
| 11-10<br>SADDR     | <p>Static Address</p> <p>Indicates how the static address is managed.</p> <ul style="list-style-type: none"> <li>00b - No static address</li> <li>01b - Static address is fixed in hardware</li> <li>10b - Hardware controls the static address dynamically (for example, from the pin strap)</li> <li>11b - SCONFIG register supplies the static address</li> </ul>                                                                                                                                                                                                                                                                                                                                                        |
| 9<br>MASTER        | <p>Controller</p> <p>Specifies whether controller capability is supported.</p> <ul style="list-style-type: none"> <li>0b - Not supported</li> <li>1b - Supported</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 8<br>—             | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 7-6                | High Data Rate Support                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HDRSUPP      | Indicates which HDR modes are supported.<br>00b - No HDR modes supported<br>01b - Double Data Rate mode supported<br>All other values are reserved.                                                                                                                                                                                                                                                                      |
| 5-2<br>IDREG | ID Register<br>Indicates which ID features are in the registers compared to what is in the hardware.<br>0000b - All ID register features below are disabled.<br>1xxxb - A Bus Characteristics Register (BCR) is available.<br>x1xxb - A Device Characteristic Register (DCR) is available.<br>xx1xb - An ID Random field is available.<br>xxx1b - ID Instance is a register, and is used if there is no PARTNO register. |
| 1-0<br>IDENA | ID 48b Handler<br>Indicates who handles the 48-bit ID value.<br>00b - Application<br>01b - Hardware<br>10b - Hardware, but the I3C module instance handles ID 48b<br>11b - A part number register (PARTNO)                                                                                                                                                                                                               |

### 39.7.22 Target Dynamic Address (SDYNADDR)

#### Offset

| Register | Offset |
|----------|--------|
| SDYNADDR | 64h    |

#### Function

The Target Dynamic Address register is filled in with the assigned address once the controller has assigned it via SETDASA or ENTDAA CCC commands. It clears if the RESETDAA CCC is used. The current validity state is also indicated through SSTATUS[DAVALID], which can be used to interrupt the processor. The DCAUSE field can be used to determine the changes, if enabled.

#### NOTE

Uses for Mapped addresses, if enabled, are accessed through the SMAPCTRLn registers.

The first dynamic address (DA[0]) may be written whether the mapping is enabled or not. If configured to allow write used to restore the DA after a power-down (an ultra-low power state that loses power to peripherals but retains the DA somewhere else). This is not required if state-retention flops are used for the DA. This mechanism only allows writes when target is disabled (and it will be ignored otherwise). If the controller uses RSTDAA or SETNEWDA, then it will over-ride this mechanism and cede (yield) to the controller-assigned DA. Note that when enabling the target, the SCONFIG[OFFLINE] bit must be set. This waits for evidence that

the bus is not in I3C HDR mode and exits when an HDR Exit pattern is seen or when 60  $\mu$ s has expired. This makes it safe to monitor START and STOP. If the application needs to do an IBI, then the application should either wait for a STOP (see STATUS) or make sure that 200  $\mu$ s have gone by with no activity (no START or STOP) before the application emits the IBI.

The MAPIDX/MAPSA model allows writing additional DAs (and SAs) into a list (the number in the list is pre-configured), any DA or SA with DAVALID = 0 are never matched. The additional DAs may be based on the bridge target CCC or done by a move (read current DA and then copy into the upper map, then invalidate the 0 map) when matching ENTDA over and over. Any mapped location can be invalidated by writing the MAPIDX and DAVALID = 0. The mapped ones are not reset by the RSTDA CCC. See the SMSGMAPADDR register.

To copy the base DA to the mapped set, the configuration has to be set up to allow it, otherwise they are distinct mechanisms.

- If used in I3C mode, a base DA is required, so the last one should not be cleared (or writing one with DAVALID = 1 is necessary).

**NACK/ACK of Mapped DAs/SAs:** The register also permits specific DAs (above the base) to NACK or ACK writes or reads, such as for bridges when the endpoint is busy. The NACK should not be set for too long, or the controller may think the target is in an error state. The model is to write with KEY = 0xA731 and the MAPIDX and DAVALID to select ACK or NACK.

**Mapping:** If write with MAPIDX != 0 and KEY = 0, then next Read returns details on the Static or Dynamic address at that location. If the read does not have MAPIDX != 0, then it was not an acceptable location.

### Diagram

| Bits  | 31    | 30 | 29     | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16      |
|-------|-------|----|--------|----|----|----|----|----|----|----|----|----|----|----|----|---------|
| R     |       |    |        |    |    |    |    |    |    |    |    |    |    |    |    | KEY     |
| W     |       |    |        |    |    |    |    |    |    |    |    |    |    |    |    |         |
| Reset | 0     | 0  | 0      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       |
| Bits  | 15    | 14 | 13     | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0       |
| R     |       |    |        |    |    |    |    |    | 0  |    |    |    |    |    |    | DAVALID |
| W     | SA10B |    | MAPS A |    |    |    |    |    |    |    |    |    |    |    |    | ID      |
| Reset | 0     | 0  | 0      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       |

### Fields

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>KEY | <p>Key</p> <p>Must set to 0xA4D9 to write DADDR field (and set DAVALID bit to 1). Write only when a target is not enabled (for restoring after power-down sleep with auto-restore). The mapped locations and base may be written when a target is enabled, but do not write when there are transactions on the I3C bus.</p> <p>KEY reads back 1 if overwritten, else KEY is 0 if assigned by the controller including when the controller changes it.</p> <p>If address mapping is allowed, then writing with KEY = 0xCB19 is used to clear the base DA.</p> <p>If Mapping is allowed, then writing with the key of 0xA731 means that MAPIDX indicates which mapped address to set to ACK or NACK, such that DAVALID = 1 if ACK, DAVALID = 0 if NACK. This allows having the address refuse write/read requests when NACK.</p> <p>When using read back from map index (write with MAPIDX != 0, KEY = 0, read) bit [16] = 1 if NACK, else 0.</p> |

Table continues on the next page...

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                            |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-13<br>SA10B | 10bit Static Address<br><br>If not 0 when MAPSA is set, stores a 10-bit static address composed of {SA10B,DADDR}. Only one static address may be stored this way, and it must be MAPIDX == 1.                                                       |
| 12<br>MAPSA    | Map a Static Address<br><br>If MAPSA = 1 on a write with MAPIDX != 0, then this sets a static address into the list, otherwise a dynamic address is used.                                                                                           |
| 11-8<br>—      | Reserved                                                                                                                                                                                                                                            |
| 7-1<br>DADDR   | Dynamic Address<br><br>This is the assigned DA, when DAVALID is 1.<br><br>Will be a static address if MAPSA is 1.                                                                                                                                   |
| 0<br>DAVALID   | Dynamic Address Valid<br><br>Determines if a Dynamic Address is assigned.<br><br>Is 1 for ACK, 0 for NACK when using the 0xA731 KEY.<br><br>0b - DANOTASSIGNED: a Dynamic Address is not assigned<br>1b - DAASSIGNED: a Dynamic Address is assigned |

### 39.7.23 Target Maximum Limits (SMAXLIMITS)

#### Offset

| Register   | Offset |
|------------|--------|
| SMAXLIMITS | 68h    |

#### Function

Indicates the limits set by the controller (or the original requested limits). The maximum limits are not enabled in the hardware design, including maximum read and write lengths. If the maximum read and write lengths are enabled, then the current setting (including default request) shows up in this register (SMAXLIMITS).

**Diagram**

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

**Fields**

| Field          | Function                                                                                                                                                                                                                               |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-28<br>—     | Reserved                                                                                                                                                                                                                               |
| 27-16<br>MAXWR | Maximum Write Length<br>Indicates the maximum write length, which must be between 8 to 4095 (saturation). The application must not set the maximum write length to a higher value than the maximum write length set by the controller. |
| 15-12<br>—     | Reserved                                                                                                                                                                                                                               |
| 11-0<br>MAXRD  | Maximum Read Length<br>Indicates the maximum read length, which must be between 16 to 4095 (saturation). The application must not set the maximum read length to a higher value than the maximum read length set by the controller.    |

**39.7.24 Target ID Part Number (SIDPARTNO)****Offset**

| Register  | Offset |
|-----------|--------|
| SIDPARTNO | 6Ch    |

**Function**

Allows an application to write the ID part number. The application must write a nonzero value into the PARTNO field, because 0 is not valid.

**Diagram**

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

**Fields**

| Field  | Function    |
|--------|-------------|
| 31-0   | Part number |
| PARTNO |             |

**39.7.25 Target ID Extension (SIDEXT)****Offset**

| Register | Offset |
|----------|--------|
| SIDEXT   | 70h    |

**Function**

Allows an application to write the ID extension of the Device Characteristic Register (DCR) and/or the Bus Characteristics Register (BCR).

**Diagram**

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

**Fields**

| Field        | Function                                                                                                                                                                                                       |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24<br>—   | Reserved                                                                                                                                                                                                       |
| 23-16<br>BCR | Bus Characteristics Register<br>Sets the value for the Bus Characteristics Register (BCR), if this field is configured. This field controls features such as Secondary Controller and slow speed requirements. |
| 15-8<br>DCR  | Device Characteristic Register<br>Sets the value for the Device Characteristic Register (DCR), if this field is configured.                                                                                    |
| 7<br>—       | Reserved                                                                                                                                                                                                       |
| 6-4<br>—     | Reserved                                                                                                                                                                                                       |
| 3-0<br>—     | Reserved                                                                                                                                                                                                       |

**39.7.26 Target Vendor ID (SVENDORID)****Offset**

| Register  | Offset |
|-----------|--------|
| SVENDORID | 74h    |

**Function**

Allows an application to write the Vendor ID. The default value is the chip vendor ID, and is set from the constant field. If using the chip vendor ID, the part number (PARTNO) does not collide with other uses. The MIPI Vendor ID is available to all companies (MIPI membership is not required). To get a vendor ID make a request at the [mipi.org](http://mipi.org) website.

**Diagram**

**Fields**

| Field       | Function                                              |
|-------------|-------------------------------------------------------|
| 31-15<br>—  | Reserved                                              |
| 14-0<br>VID | Vendor ID<br>Can be set to the 15-bit MIPI Vendor ID. |

**39.7.27 Target Time Control Clock (STCCLOCK)****Offset**

| Register | Offset |
|----------|--------|
| STCCLOCK | 78h    |

**Function**

Allows an application to dynamically set the time control clock and accuracy information. The clock frequency and accuracy are constants set by the hardware. If the clock can be adjusted (that is, divided) or if the accuracy could vary with knowable information, then the clock may be set via this register. This register must be updated whenever the clock source is changed.

**Diagram**

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

**Fields**

| Field        | Function                                                                                                                                                                              |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—   | Reserved                                                                                                                                                                              |
| 15-8<br>FREQ | Clock Frequency<br>Indicates the clock frequency in 0.5-MHz steps. For example, a value of 20 in this field indicates a frequency of 10 MHz. Default set by parameters if configured. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                         |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0      | Clock Accuracy                                                                                                                                   |
| ACCURACY | Indicates the clock accuracy in 1/10ths of %. For example, a value of 15 indicates an accuracy of 1.5%. Default set by parameters if configured. |

### 39.7.28 Target Message Map Address (SMSGMAPADDR)

#### Offset

| Register    | Offset |
|-------------|--------|
| SMSGMAPADDR | 7Ch    |

#### Function

Allows the software to determine which address is matched when STATUS[MATCHED] = 1. This register is used when the DYNADDR register builds a list of extra DAs or SAs to match. It holds the last three matches.

#### Diagram

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23        | 22 | 21 | 20 | 19 | 18             | 17 | 16        |
|-------|----|----|----|----|----|----|----|----|-----------|----|----|----|----|----------------|----|-----------|
| R     |    |    |    |    |    |    |    |    | 0         |    |    |    |    |                |    | MAPLASTM2 |
| W     |    |    |    |    |    |    |    |    |           |    |    |    |    |                |    |           |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0         | 0  | 0  | 0  | 0  | 0              | 0  | 0         |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7         | 6  | 5  | 4  | 3  | 2              | 1  | 0         |
| R     |    |    |    |    | 0  |    |    |    | MAPLASTM1 |    |    | 0  |    | LASTS<br>TA... |    | MAPLAST   |
| W     |    |    |    |    |    |    |    |    |           |    |    |    |    |                |    |           |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0         | 0  | 0  | 0  | 0  | 0              | 0  | 0         |

#### Fields

| Field     | Function                                                                   |
|-----------|----------------------------------------------------------------------------|
| 31-20     | Reserved                                                                   |
| —         |                                                                            |
| 19-16     | Matched Previous Index 2                                                   |
| MAPLASTM2 | Indicates Index 2 of the previous matched address. 0 for the base address. |
| 15-12     | Reserved                                                                   |
| —         |                                                                            |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field             | Function                                                                                                                                                                              |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11-8<br>MAPLASTM1 | Matched Previous Address Index 1<br>Indicates Index 1 of the previous matched address. 0 for the base address.                                                                        |
| 7-5<br>—          | Reserved                                                                                                                                                                              |
| 4<br>LASTSTATIC   | Last Static Address Matched<br>Indicates whether the last matched address was an I2C static address or an I3C dynamic address.<br>0b - I3C dynamic address<br>1b - I2C static address |
| 3-0<br>MAPLAST    | Matched Address Index<br>Indicates the matched address index for current or last matched message. 0 for the base address.                                                             |

### 39.7.29 Controller Extended Configuration (MCONFIG\_EXT)

#### Offset

| Register    | Offset |
|-------------|--------|
| MCONFIG_EXT | 80h    |

#### Function

Used for special extended configurations, including for I2C use.

#### Diagram

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

**Fields**

| Field                   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-20<br>—              | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 19-18<br>I3C_CASR_DELAY | <p>I3C CAS Delay After Repeated START</p> <p>Setting can be configured to delay the clock after a repeated START to provide more time for slow I3C devices. Note that max may be less if internal clock is very fast.</p> <ul style="list-style-type: none"> <li>00b - No Delay</li> <li>01b - Increases SCL clock period by 1/2.</li> <li>10b - Increases SCL clock period by 1.</li> <li>11b - Increases SCL clock period by 1 1/2.</li> </ul> |
| 17-16<br>I3C_CAS_DELAY  | <p>I3C CAS Delay after START</p> <p>Setting can be configured to delay the clock after the START to be longer by increasing SCL clock period. A Note that max may be less if internal clock is very fast.</p> <ul style="list-style-type: none"> <li>00b - No Delay</li> <li>01b - Increases SCL clock period by 1/2.</li> <li>10b - Increases SCL clock period by 1.</li> <li>11b - Increases SCL clock period by 1 1/2.</li> </ul>             |
| 15-12<br>—              | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11-8<br>—               | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 7-6<br>—                | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 5<br>—                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4<br>—                  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3-0<br>—                | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                         |

### 39.7.30 Controller Control (MCTRL)

#### Offset

| Register | Offset |
|----------|--------|
| MCTRL    | 84h    |

#### Function

Starts activities on the I3C or I2C bus. Also see the MWMSG register. A request cannot be changed when a message is in progress; the REQUEST field will become 0 automatically.

#### NOTE

Write MCTRL fields as per use case or as mentioned in [Operating modes](#). Bit read/write checking may not work independently.

#### NOTE

If [MCODE\[MSTENA\]](#) is set for I2C Controller mode (legacy I2C), only REQUEST = 1 and REQUEST = 2 are accepted. Also, fields are constrained to I2C-supported fields.

#### Diagram



#### Fields

| Field           | Function                                                                                                                                                                                                                       |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24           | Reserved                                                                                                                                                                                                                       |
| —               |                                                                                                                                                                                                                                |
| 23-16<br>RDTERM | Read Terminate Counter<br>Determines when to terminate a read operation. <ul style="list-style-type: none"> <li>• For I2C, controls when to NACK a read.</li> <li>• For I3C, can be used to terminate (end) a read.</li> </ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | <ul style="list-style-type: none"> <li>— RDTERM = 0 has no effect.</li> <li>— RDTERM = 1 terminates after the next character.</li> <li>— RDTERM = 2 terminates after the next two characters.</li> </ul> <p>Supports up to 255 characters. In DDR mode, RDTERM terminates the read based on word counts (for DDR) instead of byte counts (for SDR).</p> <p><b>NOTE</b><br/>The value 1 may be written any time to this field, but a number larger than 1 should be written when starting EmitStartAddress.</p> <p>Self clears on COMPLETE.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 15-9<br>ADDR   | <p>Address</p> <p>I3C Dynamic Address or I2C Static Address. Some values are not allowed based on which bus is used (I3C or I2C).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 8<br>DIR       | <p>Direction</p> <p>Indicates write or read</p> <p>0b - Write</p> <p>1b - Read</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7-6<br>IBIRESP | <p>In-Band Interrupt Response</p> <p>Indicates the response to use when you get an IBI from START, and when to force using a IBI ACK NACK request when completing a manual IBI. Completion of a manual IBI means that the target DA is known, and so the mandatory byte (or not) is specified by the application when acknowledging.</p> <p><b>NOTE</b><br/>Controller Request and Hot-Join always cause IBIRESP = 3 (Manual) so the application must decide.</p> <p>The MCTRL[IBIRESP] field is also used when a message is emitted in Message mode using the MWMSG_SDR or MWMSG_DDR registers.</p> <p>If an IBI with MDB (mandatory byte) is ACKed, the controller limits it to a max of eight more bytes after the MDB. RDTERM = 1 can be used with Request = None to terminate data from a target sooner.</p> <p>00b - ACK (acknowledge). When REQUEST = 1 (EmitStartAddr) or REQUEST = 7 (AutolBI), ACK with mandatory byte (or not), decided by the <a href="#">Controller In-band Interrupt Registry and Rules (MIBIRULES)</a> register. When REQUEST = 3 (IBIAckNack), ACK with no mandatory byte.</p> <p>01b - NACK (reject). Not acknowledge</p> <p>10b - Acknowledge with mandatory byte. When REQUEST = 1 or REQUEST = 7, ignore the MIBIRULES register. Do not use this setting unless only targets <i>with a mandatory byte</i> can cause an IBI. When REQUEST = 3, ACK with mandatory byte.</p> <p>11b - Manual. When REQUEST = 1 or REQUEST = 7, stop and wait for a decision using the IBI ACK NACK request. When REQUEST = 3, reserved.</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5-4<br>TYPE    | <p>Bus Type with EmitStartAddr</p> <p>Works with <a href="#">MCTRL[REQUEST]</a> to determine the bus type.</p> <p>00b - I3C. When REQUEST = 1 (EmitStartAddr) or 2 (EmitStop), the SDR mode of I3C. When REQUEST = 6 (ForceExit), the Exit pattern. When REQUEST = 4, DA comes from MWDTAB[VALUE], if not 1st time, continues to next 7E/R request.</p> <p>01b - I2C. When REQUEST = 1 (EmitStartAddr) or 2 (EmitStop), the Standard I2C protocol. When REQUEST = 4, reserved. When REQUEST = 6, reserved.</p> <p>10b - DDR. When REQUEST = 1, the HDR-DDR mode of I3C. Enter DDR mode (7E and then ENTHDR0), if the module is not in DDR mode. The 1st byte written to the Tx FIFO must be a command and already in the FIFO. To end DDR mode, use ForceExit. When REQUEST = 2, reserved. When REQUEST = 4, DA comes from MWDTAB[VALUE], if not 1st time, STOPS after assignment. When REQUEST = 6, Target Reset.</p> <p>11b - Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 3<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2-0<br>REQUEST | <p>Request</p> <p>Emits the requested operation when performing in pieces, instead of performing by message. The <a href="#">Controller Status (MSTATUS)</a> register should be checked because some requests can only be made in some states. For example, the system cannot enter SDR mode from DDR mode, and it cannot use an incorrect request in DAA mode.</p> <p>000b - NONE. Indicates that no request is present. The REQUEST field returns to NONE when finished with any request. The MSTATUS register indicates the state of the controller. See also AutoIBI mode. NONE is only written as 0 in these cases: when writing 1 to MCTRL[RDTERM] (to stop a read in progress) or when setting MCTRL[IBIRESP] for MSG use.</p> <p>001b - EMITSTARTADDR. Emit START with address and direction, either from a stopped state or in the middle of a Single Data Rate (SDR) message. If from a stopped state (IDLE), then emit start may be prevented by an event (like IBI, CR, HJ). In this case the appropriate interrupt is signaled. Emit START can be resubmitted.</p> <p>010b - EMITSTOP. Emit a STOP on bus. Must be in SDR mode. In Dynamic Address Assignment (DAA) mode, emitting stop exits DAA mode.</p> <p>011b - IBIACKNACK. Manual IBI ACK or NACK. When MCTRL[IBIRESP] has indicated a hold on an IBI to allow a manual decision, this request completes it. Uses MCTRL[IBIRESP] to provide the information.</p> <p>100b - PROCESSDAA. If not currently in Dynamic Address Assignment (DAA) mode, emits START, 7E, ENTDA sequence, then emits 7E/R to process the first target. Stops just before the new Dynamic Address (DA) is to be emitted. The DA is written using <a href="#">Controller Write Data Byte (MWDTAB)</a>, then Process DAA is requested again to write the new address, and then it starts the next unless marked to STOP. An MSTATUS indicating NACK means DA was not accepted (for example, parity error). If PROCESSDAA is NACKED on the 7E/R request, meaning no more targets need a DA, then a COMPLETE is signaled (along with DONE) and a STOP issued. If</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <p>TYPE = 2 or TYPE = 3, the DA is assigned and then it emits a STOP (instead of starting a new 7E/R request). If TYPE = 1 or TYPE = 3, then the DA is taken from the ADDR field (bits 6:0).</p> <p>101b - Reserved</p> <p>110b - Force Exit and Target Reset. Emit an Exit Pattern from any state. End Double Data Rate (DDR) mode (including MSGDDR), including a STOP afterward. If MCTRL[TYPE] is 2, perform a Target Reset action (RSTACT can prevent the reset in the target). Target Reset may follow immediately after RSTACT CCC or after STOP.</p> <p>111b - AUTOIBI. Hold in a stopped state, but auto-emit a START, 7E sequence when the target holds SDA low for an IBI. Actual IBI handling is defined by MCTRL[IBIRESP].</p> |

### 39.7.31 Controller Status (MSTATUS)

#### Offset

| Register | Offset |
|----------|--------|
| MSTATUS  | 88h    |

#### Function

Status for the controller, including which events cause interrupts. The peripherals share the IRQ (called Parallel-to-Target status).

Because a peripheral can either be in Controller or Target mode, but not both at the same time, only one (Target or Controller peripheral) can be the cause of the IRQ. If there is an IRQ and the peripheral is a controller, then this register (MSTATUS) has the status.

If there is an IRQ and the peripheral is a target, then the [Target Status \(SSTATUS\)](#) register has the status.

Self clears on COMPLETE.

If MCONFIG is set for I2C only, some states and bits will never be active (for example, DAA or IBI).

#### Diagram

| Bits  | 31          | 30 | 29         | 28             | 27         | 26           | 25             | 24           | 23      | 22         | 21          | 20 | 19             | 18    | 17 | 16 |
|-------|-------------|----|------------|----------------|------------|--------------|----------------|--------------|---------|------------|-------------|----|----------------|-------|----|----|
| R     | 0           |    |            |                | IBIADDR    |              |                |              | 0       |            |             |    | NOWM<br>AST... |       | 0  |    |
| W     |             |    |            |                |            |              |                |              |         |            |             |    | W1C            |       |    |    |
| Reset | 0           | 0  | 0          | 0              | 0          | 0            | 0              | 0            | 0       | 0          | 0           | 0  | 0              | 0     | 0  | 0  |
| Bits  | 15          | 14 | 13         | 12             | 11         | 10           | 9              | 8            | 7       | 6          | 5           | 4  | 3              | 2     | 1  | 0  |
| R     | ERRW<br>ARN | 0  | IBIWO<br>N | TXNO<br>TFU... | RXPE<br>ND | COMP<br>LETE | MCTR<br>LDO... | SLVST<br>ART | IBITYPE | NACK<br>ED | BETW<br>EEN | 0  |                | STATE |    |    |
| W     |             |    | W1C        |                |            | W1C          | W1C            | W1C          |         |            |             |    |                |       |    |    |
| Reset | 0           | 0  | 0          | 1              | 0          | 0            | 0              | 0            | 0       | 0          | 0           | 0  | 0              | 0     | 0  | 0  |

## Fields

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>—          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 30-24<br>IBIADDR | <p>IBI Address</p> <p>Indicates the address of:</p> <ul style="list-style-type: none"> <li>The IBI, when MSTATUS[IBITYPE] = 1.</li> <li>The Controller Request (CR), when MSTATUS[IBITYPE] = 2.</li> <li>7'h2 when Hot-Join, when MSTATUS[IBITYPE] = 3.</li> </ul>                                                                                                                                                                                                |
| 23-20<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 19<br>NOWMASTER  | <p>Module Is Now Controller</p> <p>Indicates when the module is now a controller. That is, it was previously a target, controllership acceptance was requested from the previous controller, and controllership was accepted. The reverse operation (controller becomes a target) does not need an interrupt, because the application grants it through the GETACCMST CCC.</p> <p>0b - Module has not become controller<br/>1b - Module has become controller</p> |
| 18-16<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 15<br>ERRWARN    | <p>Error Or Warning</p> <p>Indicates whether an error occurred, such as improper register use, overrun or underrun of FIFO or buffer, or invalid parity or CRC in a DDR read. See the <a href="#">Controller Errors and Warnings (MERRWARN)</a> register.</p> <p>0b - No error or warning<br/>1b - Error or warning</p>                                                                                                                                           |
| 14<br>—          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 13<br>IBIWON     | <p>In-Band Interrupt (IBI) Won</p> <p>Indicates whether an IBI, CR, or HJ has won the arbitration on a header address, regardless of whether it was NACKed or ACKed.</p> <p>Arbitration requires manual intervention for CR and HJ, and optionally requires it for IBI if the MCTRL[IBIRESP] = 3 (Manual).</p> <p>0b - No IBI arbitration won<br/>1b - IBI arbitration won</p>                                                                                    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12<br>TXNOTFULL | <p>TX Buffer or FIFO Not Full</p> <p>Indicates whether the buffer, FIFO or message register can accept another byte or halfword. FIFO uses trigger level. If DMA enabled for transmitting, it transfers data as long as it is not full.</p> <ul style="list-style-type: none"> <li>0b - Receive buffer or FIFO full</li> <li>1b - Receive buffer or FIFO not full</li> </ul>                                                                                                                                                                                                                                                                                                                                                                            |
| 11<br>RXPEND    | <p>RXPEND</p> <p>Indicates whether a message is being received from a target and bytes are in the input buffer or FIFO.</p> <ul style="list-style-type: none"> <li>• If using a FIFO, this message is at least one FIFO trigger's worth (a minimum of one byte in the FIFO).</li> <li>• If DMA is enabled for receiving, the DMA is signaled.</li> </ul> <p>RXPEND becomes 0 when the data is read.</p> <ul style="list-style-type: none"> <li>0b - No receive message pending</li> <li>1b - Receive message pending</li> </ul>                                                                                                                                                                                                                         |
| 10<br>COMPLETE  | <p>Complete</p> <p>Indicates whether a message has completed.</p> <ul style="list-style-type: none"> <li>• With MWMSG_SDR or MWMSG_DDR, this condition occurs when <a href="#">MWMSG_SDR_CONTROL[LEN]</a> or <a href="#">MWMSG_DDR_CONTROL[LEN]</a> reaches 0.</li> <li>• When MCTRL[REQUEST] = 1 (EmitStartAddr), this condition occurs after the end of a write operation, or after a read operation has terminated or ended.</li> <li>• With an IBI (AutoIBI or EmitStartAddr), this condition occurs at the end of IBI data (if any).</li> </ul> <ul style="list-style-type: none"> <li>0b - Not complete</li> <li>1b - Complete</li> </ul>                                                                                                         |
| 9<br>MCTRLDONE  | <p>Controller Control Done</p> <p>Indicates whether the module has completed an MCTRL request. MCTRLDONE automatically becomes 0 when writing a new control.</p> <p>When MCTRL[REQUEST] = 1 (EmitStartAddr), MCTRLDONE becomes 1 when the address goes out (and is ACKed, NACKed, or ended in an IBI). If ACKed, MSTATUS[COMPLETE] becomes 1 when the write or read data has completed.</p> <p>When MCTRL[REQUEST] = 4 (ProcessDAA), MCTRLDONE becomes 1 when the module is ready to emit the Dynamic Address (DA) for the target, or when no more targets are ACKing. This condition can be determined by using the MSTATUS[BETWEEN] and MSTATUS[STATE] fields.</p> <ul style="list-style-type: none"> <li>0b - Not done</li> <li>1b - Done</li> </ul> |
| 8<br>SLVSTART   | Target Start                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | <p>Indicates whether a target is/was requesting a START by holding SDA low. Handling starts automatically when <a href="#">MCTRL[REQUEST] = 7</a> (AutoIBI).</p> <p>0b - Target not requesting START<br/>1b - Target requesting START</p>                                                                                                                                                                                                                                                                                                                  |
| 7-6<br>IBITYPE | <p>In-Band Interrupt (IBI) Type</p> <p>Indicates the type of IBI of the last event that won the arbitration, whether the interrupt is ACKED or NACKED or pending.</p> <p>00b - NONE. No IBI. This status occurs when MSTATUS[IBIWON] becomes 0.<br/>01b - In-Band Interrupt<br/>10b - Controller Request<br/>11b - Hot-Join</p>                                                                                                                                                                                                                            |
| 5<br>NACKED    | <p>Not Acknowledged</p> <p>Indicates whether the last Start and Address sequence was NACKed (was not ACKed by the addressed target).</p> <p>0b - Not NACKed<br/>1b - NACKed (not acknowledged)</p>                                                                                                                                                                                                                                                                                                                                                         |
| 4<br>BETWEEN   | <p>Between</p> <p>Between messages or Dynamic Address Assignments (DAA), active when:</p> <ul style="list-style-type: none"> <li>MSTATUS[STATE] is MSGSDR, DDR, or DAA, and the state is between messages/DAAs. It is expecting a new messages/DAAs to start (or STOP or Exit).</li> <li>MSTATUS[STATE] is NORMACT. The module is waiting on the Transmit FIFO to be not empty or the Receive FIFO to be not full.</li> </ul> <p>0b - Inactive. For other cases.<br/>1b - Active. If STATE is MSGSDR, DDR, DAA, or NORMACT.</p>                            |
| 3<br>—         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2-0<br>STATE   | <p>State Of The Controller</p> <p>Indicates the current controller state</p> <p>000b - IDLE. Bus has stopped.<br/>001b - SLVREQ. Target request. The bus has stopped but a target is holding SDA low. If using auto-emit IBI (<a href="#">MCTRL[REQUEST] = 7</a>), the controller will not remain in this state.<br/>010b - MSGSDR. Single Data Rate Message mode, from using MWMSG_SDR<br/>011b - NORMACT. Normal active SDR mode, from using MCTRL and MWDATAAn and MRDATAAn registers. The controller remains in this state until a STOP is issued.</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | 100b - MSGDDR. Double Data Rate Message mode, from using MWMSG_DDR or using the normal method with DDR. The controller remains in the DDR state until the controller exits using EXIT (emitting the Exit pattern).<br>101b - DAA. Enter Dynamic Address Assignment (ENTDAA) mode<br>110b - IBIACK. Waiting for an In-Band Interrupt (IBI) ACK/NACK decision<br>111b - IBIRCV. Receiving an In-Band Interrupt (IBI). This state is used after IBI/CR/HJ has won an arbitration. IBIRCV state is also used for IBI mandatory byte (if any) and any bytes that follow. |

### 39.7.32 Controller In-band Interrupt Registry and Rules (MIBIRULES)

#### Offset

| Register  | Offset |
|-----------|--------|
| MIBIRULES | 8Ch    |

#### Function

Contains the rules for using IBI, and keeps a registry of the targets that use the IBI byte.

Defines the IBI mandatory byte rules for the targets. Determines which targets do (or do not) have a mandatory byte.

Concerning ADDRn fields: The address is six bits. Assuming that MIBIRULES[MSB0] = 1, the most significant bit of each address is 0. In this case, each address is seven bits (usually written as A7 to A1) and A7 must be 0. If the application does not use that optimal convention, the Manual method of IBI ACK handling must be used (see [MCTRL\[IBIRESP\]](#) ).

By default, the ADDRn values indicate the targets with a mandatory byte. If MIBIRULES[NOBYTE] = 1, the ADDRn values indicate targets that do not have a mandatory IBI byte.

#### NOTE

A7 = 0 is only needed for targets that use IBI. For legacy I2C devices, A7 can use any valid value, because I2C devices cannot cause an IBI.

#### Diagram

| Bits  | 31     | 30   | 29    | 28 | 27    | 26 | 25    | 24 | 23    | 22 | 21    | 20 | 19 | 18 | 17 | 16 |
|-------|--------|------|-------|----|-------|----|-------|----|-------|----|-------|----|----|----|----|----|
| R     | NOBYTE | MSB0 | ADDR4 |    |       |    | ADDR3 |    |       |    | ADDR2 |    |    |    |    |    |
| W     | 0      | 0    | 0     | 0  | 0     | 0  | 0     | 0  | 0     | 0  | 0     | 0  | 0  | 0  | 0  | 0  |
| Reset | 0      | 0    | 0     | 0  | 0     | 0  | 0     | 0  | 0     | 0  | 0     | 0  | 0  | 0  | 0  | 0  |
| Bits  | 15     | 14   | 13    | 12 | 11    | 10 | 9     | 8  | 7     | 6  | 5     | 4  | 3  | 2  | 1  | 0  |
| R     | ADDR2  |      |       |    | ADDR1 |    |       |    | ADDR0 |    |       |    |    |    |    |    |
| W     | 0      | 0    | 0     | 0  | 0     | 0  | 0     | 0  | 0     | 0  | 0     | 0  | 0  | 0  | 0  | 0  |
| Reset | 0      | 0    | 0     | 0  | 0     | 0  | 0     | 0  | 0     | 0  | 0     | 0  | 0  | 0  | 0  | 0  |

**Fields**

| Field          | Function                                                                                                                                                                       |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>NOBYTE   | No IBI byte<br>Indicates whether the ADDRn fields refer to targets with or without a mandatory IBI byte.<br>0b - With mandatory IBI byte<br>1b - Without mandatory IBI byte    |
| 30<br>MSB0     | Most Significant Address Bit Is 0<br>Assigning 1 to this field allows the START header to be optimized.<br>0b - MSB is not 0.<br>1b - For all I3C dynamic addresses, MSB is 0. |
| 29-24<br>ADDR4 | ADDR4<br>Address of target with or without Mandatory IBI byte. If 0, then the address does not apply.                                                                          |
| 23-18<br>ADDR3 | ADDR3<br>Address of target with or without Mandatory IBI byte. If 0, then the address does not apply.                                                                          |
| 17-12<br>ADDR2 | ADDR2<br>Address of target with or without Mandatory IBI byte. If 0, then the address does not apply.                                                                          |
| 11-6<br>ADDR1  | ADDR1<br>Address of target with or without Mandatory IBI byte. If 0, then the address does not apply.                                                                          |
| 5-0<br>ADDR0   | ADDR0<br>Address of target with or without Mandatory IBI byte. If 0, then the address does not apply.                                                                          |

**39.7.33 Controller Interrupt Set (MINTSET)****Offset**

| Register | Offset |
|----------|--------|
| MINTSET  | 90h    |

**Function**

Set interrupt enables for select bits in [Controller Status \(MSTATUS\)](#). Reading the MINTSET register returns the status of the interrupt enables.

- To activate an interrupt enable, write 1 to its field.
- To disable an interrupt enable, write 1 to the appropriate field in the [Controller Interrupt Clear \(MINTCLR\)](#) register. Writing 0 to the interrupt enable in this register (MINTSET) does not disable the interrupt.

The interrupt registers allow the masking of interrupt sources, as well as checking which interrupts have activated in the MSTATUS register. The normal method is to enable an interrupt and then once that interrupt fires, clear the interrupt either by writing the MSTATUS register or via an action on the corresponding data register. The interrupt is level-held, meaning that the interrupt

remains 1 until the cause is cleared by some method. The module prevents races; if a new event comes in, that new event is not lost.

These interrupts are parallel to the [Target Interrupt Set \(SINTSET\)](#) / [Target Interrupt Clear \(SINTCLR\)](#) set, and only one interrupt set is active depending on state (controller or target operation).

- MINTSET: Sets interrupt enables for MSTATUS bits. Reading MINTSET register returns the status of the interrupt enables.
- MINTCLR: Clears interrupt enables for MSTATUS bits.
- MINTMASKED: Returns the value of the MSTATUS bits ANDed with their interrupt enables.

### Diagram

| Bits  | 31          | 30     | 29              | 28         | 27           | 26             | 25          | 24    | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-------------|--------|-----------------|------------|--------------|----------------|-------------|-------|----|----|----|----|----|----|----|----|
| Reset | 0           | 0      | 0               | 0          | 0            | 0              | 0           | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bits  | 15          | 14     | 13              | 12         | 11           | 10             | 9           | 8     | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     | ERRW<br>ARN | 0<br>N | IBIWO<br>TFU... | TXNO<br>ND | RXPE<br>LETE | COMP<br>LDO... | MCTR<br>ART | SLVST | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| W     |             |        |                 |            |              |                |             |       |    |    |    |    |    |    |    |    |
| Reset | 0           | 0      | 0               | 0          | 0            | 0              | 0           | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

### Fields

| Field           | Function                                                                                                                                                                                                                                                                                                   |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-20           | Reserved                                                                                                                                                                                                                                                                                                   |
| —               |                                                                                                                                                                                                                                                                                                            |
| 19<br>NOWMASTER | Now Controller (now this I3C module is a controller) Interrupt Enable<br><br>Indicates when the module is now a controller. That is, it was previously a target, controllership acceptance was requested from the previous controller, and controllership was accepted.<br><br>0b - Disable<br>1b - Enable |
| 18-16           | Reserved                                                                                                                                                                                                                                                                                                   |
| —               |                                                                                                                                                                                                                                                                                                            |
| 15<br>ERRWARN   | Error or Warning (ERRWARN) Interrupt Enable<br><br>Indicates whether an error occurred, such as improper register use, overrun or underrun of FIFO or buffer, or invalid parity or CRC in a DDR read.<br><br>0b - Disable<br>1b - Enable                                                                   |
| 14<br>—         | Reserved                                                                                                                                                                                                                                                                                                   |

Table continues on the next page...

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                              |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13<br>IBIWON    | In-Band Interrupt (IBI) Won Interrupt Enable<br><br>Indicates whether an IBI, CR, or HJ has won the arbitration on a header address, regardless of whether it was NACKed or ACKed.<br><br>0b - Disable<br>1b - Enable |
| 12<br>TXNOTFULL | Transmit Buffer/FIFO is not full interrupt enable<br><br>Indicates whether the buffer, FIFOm or message register can accept another byte or halfword.<br><br>0b - Disable<br>1b - Enable                              |
| 11<br>RXPEND    | Receive Pending Interrupt Enable<br><br>Indicates whether a message is being received from a target and bytes are in the input buffer or FIFO.                                                                        |
| 10<br>COMPLETE  | Completed Message Interrupt Enable<br><br>Indicates whether a message has completed.<br><br>0b - Disable<br>1b - Enable                                                                                               |
| 9<br>MCTRLDONE  | Controller Control Done Interrupt Enable<br><br>Indicates whether the module has completed an MCTRL request.<br><br>0b - Disable<br>1b - Enable                                                                       |
| 8<br>SLVSTART   | Target Start Interrupt Enable<br><br>Indicates whether a target is/was requesting a START by holding SDA low.<br><br>0b - Disable<br>1b - Enable                                                                      |
| 7-0<br>—        | Reserved                                                                                                                                                                                                              |

### 39.7.34 Controller Interrupt Clear (MINTCLR)

#### Offset

| Register | Offset |
|----------|--------|
| MINTCLR  | 94h    |

**Function**

Clears interrupt enables for select **Controller Status (MSTATUS)** fields. Writing a 1 clears the corresponding interrupt enable. Writing a 0 has no effect.

**Diagram**

| Bits  | 31          | 30 | 29         | 28             | 27         | 26           | 25             | 24           | 23 | 22 | 21 | 20 | 19             | 18 | 17 | 16 |
|-------|-------------|----|------------|----------------|------------|--------------|----------------|--------------|----|----|----|----|----------------|----|----|----|
| R     |             |    |            |                |            |              |                |              | 0  |    |    |    | NOWM<br>AST... |    | 0  |    |
| W     |             |    |            |                |            |              |                |              |    |    |    |    | W1C            |    |    |    |
| Reset | u           | u  | u          | u              | u          | u            | u              | u            | u  | u  | u  | u  | u              | u  | u  | u  |
| Bits  | 15          | 14 | 13         | 12             | 11         | 10           | 9              | 8            | 7  | 6  | 5  | 4  | 3              | 2  | 1  | 0  |
| R     | ERRW<br>ARN | 0  | IBIW<br>ON | TXNO<br>TFU... | RXPE<br>ND | COMP<br>LETE | MCTR<br>LDO... | SLVST<br>ART |    |    |    |    |                | 0  |    |    |
| W     | W1C         |    | W1C        | W1C            | W1C        | W1C          | W1C            | W1C          |    |    |    |    |                |    |    |    |
| Reset | u           | u  | u          | u              | u          | u            | u              | u            | u  | u  | u  | u  | u              | u  | u  | u  |

**Fields**

| Field           | Function                                                                                                |
|-----------------|---------------------------------------------------------------------------------------------------------|
| 31-20<br>—      | Reserved                                                                                                |
| 19<br>NOWMASTER | NOWCONTROLLER Interrupt Enable Clear<br>0b - No effect<br>1b - Corresponding interrupt enable becomes 0 |
| 18-16<br>—      | Reserved                                                                                                |
| 15<br>ERRWARN   | ERRWARN Interrupt Enable Clear<br>0b - No effect<br>1b - Corresponding interrupt enable becomes 0       |
| 14<br>—         | Reserved                                                                                                |
| 13<br>IBIWON    | IBIWON Interrupt Enable Clear<br>0b - No effect<br>1b - Corresponding interrupt enable becomes 0        |
| 12<br>TXNOTFULL | TXNOTFULL Interrupt Enable Clear<br>0b - No effect<br>1b - Corresponding interrupt enable becomes 0     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                            |
|----------------|-----------------------------------------------------------------------------------------------------|
| 11<br>RXPEND   | RXPEND Interrupt Enable Clear<br>0b - No effect<br>1b - Corresponding interrupt enable becomes 0    |
| 10<br>COMPLETE | COMPLETE Interrupt Enable Clear<br>0b - No effect<br>1b - Corresponding interrupt enable becomes 0  |
| 9<br>MCTRLDONE | MCTRLDONE Interrupt Enable Clear<br>0b - No effect<br>1b - Corresponding interrupt enable becomes 0 |
| 8<br>SLVSTART  | SLVSTART Interrupt Enable Clear<br>0b - No effect<br>1b - Corresponding interrupt enable becomes 0  |
| 7-0<br>—       | Reserved                                                                                            |

### 39.7.35 Controller Interrupt Mask (MINTMASKED)

#### Offset

| Register   | Offset |
|------------|--------|
| MINTMASKED | 98h    |

#### Function

Returns the status of enabled interrupts (the value of [Controller Status \(MSTATUS\)](#) ANDed with the value of [Controller Interrupt Set \(MINTSET\)](#) ).

**Diagram**

| Bits  | 31          | 30 | 29         | 28             | 27         | 26           | 25             | 24           | 23 | 22 | 21 | 20 | 19             | 18 | 17 | 16 |
|-------|-------------|----|------------|----------------|------------|--------------|----------------|--------------|----|----|----|----|----------------|----|----|----|
| R     |             |    |            |                |            |              |                |              | 0  |    |    |    | NOWM<br>AST... |    |    | 0  |
| W     |             |    |            |                |            |              |                |              |    |    |    |    |                |    |    |    |
| Reset | 0           | 0  | 0          | 0              | 0          | 0            | 0              | 0            | 0  | 0  | 0  | 0  | 0              | 0  | 0  | 0  |
| Bits  | 15          | 14 | 13         | 12             | 11         | 10           | 9              | 8            | 7  | 6  | 5  | 4  | 3              | 2  | 1  | 0  |
| R     | ERRW<br>ARN | 0  | IBIWO<br>N | TXNO<br>TFU... | RXPE<br>ND | COMP<br>LETE | MCTR<br>LDO... | SLVST<br>ART |    |    |    |    | 0              |    |    |    |
| W     |             |    |            |                |            |              |                |              |    |    |    |    |                |    |    |    |
| Reset | 0           | 0  | 0          | 0              | 0          | 0            | 0              | 0            | 0  | 0  | 0  | 0  | 0              | 0  | 0  | 0  |

**Fields**

| Field           | Function                                                                                                          |
|-----------------|-------------------------------------------------------------------------------------------------------------------|
| 31-20<br>—      | Reserved                                                                                                          |
| 19<br>NOWMASTER | NOWCONTROLLER Interrupt Mask<br>0b - Interrupt not enabled and/or not active<br>1b - Interrupt enabled and active |
| 18-16<br>—      | Reserved                                                                                                          |
| 15<br>ERRWARN   | ERRWARN Interrupt Mask<br>0b - Interrupt not enabled and/or not active<br>1b - Interrupt enabled and active       |
| 14<br>—         | Reserved                                                                                                          |
| 13<br>IBIWON    | IBIWON Interrupt Mask<br>0b - Interrupt not enabled and/or not active<br>1b - Interrupt enabled and active        |
| 12<br>TXNOTFULL | TXNOTFULL Interrupt Mask<br>0b - Interrupt not enabled and/or not active<br>1b - Interrupt enabled and active     |
| 11<br>RXPEND    | RXPEND Interrupt Mask                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                          |
|----------------|-------------------------------------------------------------------------------------------------------------------|
| 10<br>COMPLETE | COMPLETE Interrupt Mask<br><br>0b - Interrupt not enabled and/or not active<br>1b - Interrupt enabled and active  |
| 9<br>MCTRLDONE | MCTRLDONE Interrupt Mask<br><br>0b - Interrupt not enabled and/or not active<br>1b - Interrupt enabled and active |
| 8<br>SLVSTART  | SLVSTART Interrupt Mask<br><br>0b - Interrupt not enabled and/or not active<br>1b - Interrupt enabled and active  |
| 7-0<br>—       | Reserved                                                                                                          |

### 39.7.36 Controller Errors and Warnings (MERRWARN)

#### Offset

| Register | Offset |
|----------|--------|
| MERRWARN | 9Ch    |

#### Function

Contains errors and warnings. When any errors or warnings are not 0, then the [MSTATUS\[ERRWARN\]](#) bit is 1.

Parallel-to-target ERRWARN:

- In Controller mode, use this register (MERRWARN).
- In Target mode, use the [Target Errors and Warnings \(SERRWARN\)](#) register.

The error fields in both registers (MERRWARN and SERRWARN) are similar in meaning.

**Diagram**

| Bits  | 31 | 30 | 29 | 28 | 27  | 26   | 25   | 24 | 23 | 22 | 21 | 20      | 19     | 18     | 17     | 16    |
|-------|----|----|----|----|-----|------|------|----|----|----|----|---------|--------|--------|--------|-------|
| R     |    |    |    |    | 0   |      |      |    |    |    | 0  | TIMEOUT | INVREQ | MSGERR | OWRITE | OREAD |
| W     |    |    |    |    |     |      |      |    |    |    |    | W1C     | W1C    | W1C    | W1C    | W1C   |
| Reset | 0  | 0  | 0  | 0  | 0   | 0    | 0    | 0  | 0  | 0  | 0  | 0       | 0      | 0      | 0      | 0     |
| Bits  | 15 | 14 | 13 | 12 | 11  | 10   | 9    | 8  | 7  | 6  | 5  | 4       | 3      | 2      | 1      | 0     |
| R     | 0  |    | 0  |    | 0   | HCRC | HPAR |    | 0  |    |    | TERM    | WRABT  | NACK   | URUN   | 0     |
| W     |    |    |    |    | W1C | W1C  |      |    |    |    |    | W1C     | W1C    | W1C    | W1C    |       |
| Reset | 0  | 0  | 0  | 0  | 0   | 0    | 0    | 0  | 0  | 0  | 0  | 0       | 0      | 0      | 0      | 0     |

**Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-22<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 21<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 20<br>TIMEOUT | <p>Timeout Error</p> <p>Indicates an error caused by the module stalling for too long in a frame. This stalling occurs when:</p> <ul style="list-style-type: none"> <li>The Transmit FIFO or Receive FIFO is not handled, and the bus is stuck in the middle of a message.</li> <li>No STOP is issued and between messages.</li> <li>IBI manual is used and no decision has been made.</li> </ul> <p>The maximum stall period is 10 kHz or 100 µs.</p> <p>0b - No error<br/>1b - Error</p> |
| 19<br>INVREQ  | <p>Invalid Request Error</p> <p>Indicates an error caused by an invalid use of a request:</p> <ul style="list-style-type: none"> <li>Not using IBI ACK NACK when stopped in manual hold for IBI acknowledgment.</li> <li>Using a request other than ForceStop or ForceExit while in a message. Other requests are valid when the message is done.</li> <li>Other mismatched uses (for example, IBI ACK NACK while in normal states).</li> </ul> <p>0b - No error<br/>1b - Error</p>        |
| 18            | <p>Message Error</p> <p>Indicates an error caused by :</p>                                                                                                                                                                                                                                                                                                                                                                                                                                 |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                                          |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MSGERR       | <ul style="list-style-type: none"> <li>Trying to write to or read from MWMSG_SDR register while in a DDR message.</li> <li>Trying to write to or read from MWMSG_DDR register while in a SDR message.</li> </ul> 0b - No error<br>1b - Error                                                                                                      |
| 17<br>OWRITE | Over-write Error<br>Indicates an error caused by trying to write to the Controller Write Data Byte Register (MWDATAB) when the FIFO is full.<br>0b - No error<br>1b - Error                                                                                                                                                                       |
| 16<br>OREAD  | Over-read Error<br>Indicates an error caused by <ul style="list-style-type: none"> <li>Trying to read from the <a href="#">Controller Read Data Byte (MRDATAB)</a> register when the FIFO is empty.</li> <li>Trying to read from MRMSG_SDR register or MRMSG_DDR register when no message has yet started.</li> </ul> 0b - No error<br>1b - Error |
| 15-13<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                          |
| 12<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                          |
| 11<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                          |
| 10<br>HCRC   | High Data Rate CRC Error<br>Indicates that a Cyclic Redundancy Check (CRC) error occurred from a DDR read.<br>0b - No error<br>1b - Error                                                                                                                                                                                                         |
| 9<br>HPAR    | High Data Rate Parity<br>Indicates a parity error from a DDR read, including a bad preamble on a read. Does not stop the read, because it is not safe to terminate; the read data may become mis-framed. Ends on a run of 1 second.<br>0b - No error<br>1b - Error                                                                                |
| 8-5          | Reserved                                                                                                                                                                                                                                                                                                                                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —          |                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 4<br>TERM  | <p>Terminate Error</p> <p>Indicates an error when this controller terminates a target read because the read exceeded the count for the message. This error only valid when using the MWMSG_SDR or MWMSG_DDR register.</p> <p>If the MWMSG_SDR or MWMSG_DDR register is written, this field automatically becomes 0.</p> <p>0b - No error<br/>1b - Error</p>                                                                           |
| 3<br>WRABT | <p>Write Abort Error</p> <p>Indicates an error caused by the I2C target NACKing the write data, terminating the message. For example, the controller is writing in I2C and the Target NACKed the write.</p> <p>If the MCTRL register is written, this field automatically becomes 0.</p> <p>0b - No error<br/>1b - Error</p>                                                                                                          |
| 2<br>NACK  | <p>Not Acknowledge Error</p> <p>Indicates an error caused by the target or targets NACKing (not acknowledging) the last address. If 7Eh was the address, then all targets NACKed the last address.</p> <p>If the MCTRL register is written, this field automatically becomes 0.</p> <p><b>NOTE</b><br/>In HDR mode, this error occurs when an address is not accepted (as opposed to NACKed).</p> <p>0b - No error<br/>1b - Error</p> |
| 1<br>URUN  | <p>Underrun error</p> <p>Indicates an underrun for HDR-BT. This error occurs when attempting to write from an empty transmit FIFO.</p> <p>0b - No error<br/>1b - Error</p>                                                                                                                                                                                                                                                            |
| 0<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                              |

### 39.7.37 Controller DMA Control (MDMACTL)

#### Offset

| Register | Offset |
|----------|--------|
| MDMACTL  | A0h    |

## Function

Allows DMA to be used for inbound and outbound messages. DMA is much more useful for a controller than for a target, because the controller is directing the bus traffic and actions. DMA can be used with a controller in these ways:

- Push or pull data to accompany an [MCTRL\[REQUEST\] = 1](#) (EmitStartAddr) request written by the processor.
- Implementing message mode completely controlled by DMA.

## Diagram

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

## Fields

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| —        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7-6      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| —        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 5-4      | DMA Width                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| DMAWIDTH | Specifies the data width of DMA operations.<br>00b,01b - Byte<br>10b - Halfword (16 bits). This setting ensures that two bytes are free/available in FIFO.<br>11b - Reserved                                                                                                                                                                                                                                                                                                                                          |
| 3-2      | DMA To Bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| DMATB    | Represents the DMA Write (to-bus) trigger. When DMAFB = 1 or DMAFB = 2, the module starts request DMA when a transmit trigger occurs. See <a href="#">Controller Data Control (MDATACTRL) register</a> . The module requests until full, unless the DMA is set up as a trigger.<br>DMAFB becomes 0 when <a href="#">MSTATUS[ERRWARN]</a> = 1.<br>00b - DMA is not used<br>01b - Enable DMA for one frame (ended by DMA or Terminated). STOP or START causes DMATB to become 0. See <a href="#">SCONFIG[MATCHSS]</a> . |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | <p>10b - Enable DMA until DMA is turned off. Normally, DMA ENABLE should only be used in Controller Message mode.</p> <p>11b - Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1-0<br>DMAFB | <p>DMA From Bus</p> <p>Represents the DMA Read (from-bus) trigger. When DMAFB = 1 or DMAFB = 2, the module requests DMA when a receive trigger occurs. See <a href="#">Controller Data Control (MDATACTRL)</a> register. The module requests until empty, unless the DMA is set up as a trigger.</p> <p>DMAFB becomes 0 when <a href="#">MSTATUS[ERRWARN]</a> = 1.</p> <p><b>NOTE</b></p> <p>Do not enable DMA after a transaction starts. It must be enabled only while enabling the controller and interrupts, to avoid any kind of RX FIFO overrun.</p> <p>00b - DMA is not used</p> <p>01b - Enable DMA for one frame. STOP or repeated START causes DMAFB to automatically become 0. See <a href="#">SCONFIG[MATCHSS]</a>.</p> <p>10b - Enable DMA until DMA is turned off</p> <p>11b - Reserved</p> |

### 39.7.38 Controller Data Control (MDATACTRL)

#### Offset

| Register  | Offset |
|-----------|--------|
| MDATACTRL | ACh    |

#### Function

Assists in data control when there is no FIFO. It also assists the FIFO when FIFO is available (regardless of size). This assistance allows some control over the FIFO behavior. In particular, it provides control over when to interrupt when a particular state of fullness or emptiness is reached. It also controls behavior related to width, when the width is not one-byte wide.

**NOTE**

When flushing a FIFO while DMA is in use, disable the DMA channel first. FIFO flush should not be used when a message (in that direction) is in flight.

The Controller Data Control register is an alias of the [Target Data Control \(SDATACTRL\)](#) register.

**Diagram**

| Bits  | 31          | 30         | 29 | 28      | 27 | 26 | 25 | 24 | 23     | 22     | 21         | 20 | 19          | 18 | 17          | 16 |
|-------|-------------|------------|----|---------|----|----|----|----|--------|--------|------------|----|-------------|----|-------------|----|
| R     | RXEM<br>PTY | TXFUL<br>L | 0  | RXCOUNT |    |    |    | 0  | 0      | 0      | TXCOUNT    |    |             |    |             |    |
|       |             |            |    |         |    |    |    |    |        |        |            |    |             |    |             |    |
| Reset | 1           | 0          | 0  | 0       | 0  | 0  | 0  | 0  | 0      | 0      | 0          | 0  | 0           | 0  | 0           | 0  |
| Bits  | 15          | 14         | 13 | 12      | 11 | 10 | 9  | 8  | 7      | 6      | 5          | 4  | 3           | 2  | 1           | 0  |
| R     | 0           |            |    |         |    |    |    |    | RXTRIG | TXTRIG |            |    | 0           |    |             |    |
|       |             |            |    |         |    |    |    |    |        |        | UNLO<br>CK |    | FLUS<br>HFB |    | FLUS<br>HTB |    |
| Reset | 0           | 0          | 0  | 0       | 0  | 0  | 0  | 0  | 0      | 0      | 1          | 1  | 0           | 0  | 0           | 0  |

**Fields**

| Field            | Function                                                                                                                                                                                              |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>RXEMPTY    | Receive Is Empty<br><br>0b - Receive FIFO or buffer is not yet empty.<br><br>1b - Receive FIFO or buffer is empty.                                                                                    |
| 30<br>TXFULL     | Transmit Is Full<br><br>0b - Transmit FIFO or buffer is not yet full.<br><br>1b - Transmit FIFO or buffer is full.                                                                                    |
| 29<br>—          | Reserved                                                                                                                                                                                              |
| 28-24<br>RXCOUNT | Receive Byte Count<br><br>Contains the count of bytes in the Receive FIFO or buffer.                                                                                                                  |
| 23-22<br>—       | Reserved                                                                                                                                                                                              |
| 21<br>—          | Reserved                                                                                                                                                                                              |
| 20-16<br>TXCOUNT | Transmit Byte Count<br><br>Contains the count of bytes waiting in the TXFIFO. This count is the number of bytes the application has written to the Transmit FIFO that have not yet gone onto the bus. |
| 15-8<br>—        | Reserved                                                                                                                                                                                              |
| 7-6              | Receive Trigger Level<br><br>Indicates trigger level for Receive fullness when using a FIFO. Affects RXPEND interrupt.                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                   |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RXTRIG        | 00b - Trigger when not empty<br>01b - Trigger when 1/4 full or more<br>10b - Trigger when 1/2 full or more<br>11b - Trigger when 3/4 full or more                                                                                                                                          |
| 5-4<br>TXTRIG | Transmit Trigger Level<br>Indicates trigger level for Transmit emptiness when using a FIFO. Affects TXNOTFULL interrupt.<br>00b - Trigger when empty<br>01b - Trigger when 1/4 full or less<br>10b - Trigger when 1/2 full or less<br>11b - Default. Trigger when 1 less than full or less |
| 3<br>UNLOCK   | Unlock<br><b>NOTE</b><br>UNLOCK must be 1 in the same cycle while writing to TXTRIG or RXTRIG.<br>0b - Locked. RXTRIG and TXTRIG fields cannot be changed on a write.<br>1b - Unlocked. RXTRIG and TXTRIG fields can be changed on a write.                                                |
| 2<br>—        | Reserved                                                                                                                                                                                                                                                                                   |
| 1<br>FLUSHFB  | Flush From-bus Buffer or FIFO<br>FLUSHFB is not normally used.<br>0b - No action<br>1b - Flush the buffer                                                                                                                                                                                  |
| 0<br>FLUSHTB  | Flush To-bus Buffer or FIFO<br>Used when the controller terminates a to-bus message (read) prematurely.<br>0b - No action<br>1b - Flush the buffer                                                                                                                                         |

### 39.7.39 Controller Write Data Byte (MWDATAB)

Offset

| Register | Offset |
|----------|--------|
| MWDATAB  | B0h    |

## Function

Allows writing bytes to send onto the bus. Only used when using [Controller Control \(MCTRL\)](#) to start the message. If MWMSG\_SDR or MWMSG\_DDR is used to start a message, that interface must be used exclusively.

The MWDATA register is the alias of the [Target Write Data Byte \(SWDATAB\)](#) register.

## Diagram

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23 | 22 | 21 | 20 | 19    | 18 | 17 | 16       |
|-------|----|----|----|----|----|----|----|-----|----|----|----|----|-------|----|----|----------|
| R     |    |    |    |    |    |    |    |     | 0  |    |    |    |       |    |    |          |
| W     |    |    |    |    |    |    |    |     |    |    |    |    |       |    |    | END_ALSO |
| Reset | u  | u  | u  | u  | u  | u  | u  | u   | u  | u  | u  | u  | u     | u  | u  | u        |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7  | 6  | 5  | 4  | 3     | 2  | 1  | 0        |
| R     |    |    |    |    | 0  |    |    |     |    |    |    |    |       |    |    |          |
| W     |    |    |    |    |    |    |    | END |    |    |    |    | VALUE |    |    |          |
| Reset | u  | u  | u  | u  | u  | u  | u  | u   | u  | u  | u  | u  | u     | u  | u  | u        |

## Fields

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-17<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 16<br>END_ALSO | <p>End of Message Also</p> <p>Indicates end of message, used to end outbound message normally. Every message must indicate when it is the last message to be sent. This method can be used with the MDATABE register.</p> <p>This field is required for I3C and is optional for I2C. For HDR-DDR, the byte with the END_ALSO must be an even byte (second, fourth, sixth, and so on) because DDR uses byte-pairs.</p> <p>0b - Not the end. More bytes are assumed to be in the message.</p> <p>1b - End. The END bit marks the last byte of the message.</p> |
| 15-9<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 8<br>END       | <p>End of Message</p> <p>Indicates the end of a message. This field is required for I3C and is optional for I2C. For HDR-DDR, the byte with the END must be an even byte (second, fourth, sixth, and so on) because DDR uses byte-pairs.</p> <p>0b - Not the end. More bytes are assumed to be in the message.</p> <p>1b - End. The END bit marks the last byte of the message.</p>                                                                                                                                                                          |
| 7-0            | <p>Data Byte</p> <p>Represents the byte written to the target (stored in Transmit FIFO).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                      |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| VALUE | <ul style="list-style-type: none"> <li>If I3C, the block computes the parity.</li> <li>For I2C, the block manages the ACK or NACK.</li> </ul> |

### 39.7.40 Controller Write Data Byte End (MWDATABASE)

#### Offset

| Register   | Offset |
|------------|--------|
| MWDATABASE | B4h    |

#### Function

Allows writing the last byte to send onto the bus. Only used when using [Controller Control \(MCTRL\)](#) to start the message. If MWMSG\_SDR or MWMSG\_DDR is used to start a message, that interface must be used exclusively. The MWDATABASE register is the alias of the [Target Write Data Byte End \(SWDATABASE\)](#) register.

#### NOTE

MWDATABASE can also indicate END using bit 8.

#### Diagram

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

#### Fields

| Field        | Function                                                                                                                                                                                                                                   |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8<br>—    | Reserved                                                                                                                                                                                                                                   |
| 7-0<br>VALUE | <p>Data</p> <p>Represents the last byte written to the target (stored in Transmit FIFO).</p> <ul style="list-style-type: none"> <li>If I3C, the block computes the parity.</li> <li>For I2C, the block manages the ACK or NACK.</li> </ul> |

### 39.7.41 Controller Write Data Halfword (MWDATAH)

#### Offset

| Register | Offset |
|----------|--------|
| MWDATAH  | B8h    |

#### Function

Allows writing a halfword (pair of bytes) to the bus unless an external FIFO is used. Sends the low byte followed by the high byte. An end-of-data (last) marker bit is allowed (or must be 0). A halfword should not be written unless there is room for both, as indicated by the use of Transmit FIFO level trigger or [MDATACTRL\[TXCOUNT\]](#).

The MWDATAH register is the alias of the [Target Write Data Half-word \(SWDATAH\)](#) register.

#### Diagram

| Bits  | 31 | 30 | 29 | 28 | 27    | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19    | 18 | 17 | 16  |
|-------|----|----|----|----|-------|----|----|----|----|----|----|----|-------|----|----|-----|
| R     |    |    |    |    |       |    |    |    | 0  |    |    |    |       |    |    |     |
| W     |    |    |    |    |       |    |    |    |    |    |    |    |       |    |    | END |
| Reset | u  | u  | u  | u  | u     | u  | u  | u  | u  | u  | u  | u  | u     | u  | u  | u   |
| Bits  | 15 | 14 | 13 | 12 | 11    | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3     | 2  | 1  | 0   |
| R     |    |    |    |    |       |    |    |    |    |    |    |    |       |    |    |     |
| W     |    |    |    |    | DATA1 |    |    |    |    |    |    |    | DATA0 |    |    |     |
| Reset | u  | u  | u  | u  | u     | u  | u  | u  | u  | u  | u  | u  | u     | u  | u  | u   |

#### Fields

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-17<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 16<br>END     | <p>End of message</p> <p>Indicates the end of a message. For this register, this field always marks DATA1 as the end. This field is required for I3C and is optional for I2C.</p> <p>For HDR-DDR, the byte with the END must be an even byte (second, fourth, sixth, and so on) because DDR uses byte-pairs.</p> <p>0b - Not the end. More bytes are assumed to be in the message.</p> <p>1b - End. The END bit marks the last byte of the message.</p> |
| 15-8<br>DATA1 | <p>Data Byte 1</p> <p>Represents the second byte that is sent to the target (written to Transmit FIFO).</p>                                                                                                                                                                                                                                                                                                                                             |
| 7-0<br>DATA0  | <p>Data Byte 0</p> <p>Represents the first byte that is sent to the target (written to Transmit FIFO).</p>                                                                                                                                                                                                                                                                                                                                              |

### 39.7.42 Controller Write Data Halfword End (MWDATAHE)

#### Offset

| Register | Offset |
|----------|--------|
| MWDATAHE | BCh    |

#### Function

Allows writing a half word of data, which is the end (the last byte of the half word is the end). Writes the half word (byte pair) just like [Controller Write Data Halfword \(MWDATAH\)](#), but marks the second byte as end-of-data (last byte).

For HDR-DDR, the byte with the END must be an even (second, fourth, sixth, and so on) because DDR uses byte-pairs.

A half-word should not be written unless there is room for both, as indicated by the use of Transmit FIFO level trigger or [MDATACTRL\[TXCOUNT\]](#).

The MWDATAHE register is the alias of the [Target Write Data Half-word End \(SWDATAHE\)](#) register.

#### Diagram



#### Fields

| Field         | Function                                                                                         |
|---------------|--------------------------------------------------------------------------------------------------|
| 31-16<br>—    | Reserved                                                                                         |
| 15-8<br>DATA1 | Data Byte 1<br>Represents the second byte that is sent to the target (written to Transmit FIFO). |
| 7-0<br>DATA0  | Data Byte 0<br>Represents the first byte that is sent to the target (written to Transmit FIFO).  |

### 39.7.43 Controller Read Data Byte (MRDATAB)

#### Offset

| Register | Offset |
|----------|--------|
| MRDATAB  | C0h    |

#### Function

Allows reading bytes written by the target after an SDR Read, or DAA or DDR. Only used when using [Controller Control \(MCTRL\)](#) to start the message. If MWMSG\_SDR or MWMSG\_DDR is used to start a message, that interface must be used exclusively.

This register is the alias of the [Target Read Data Byte \(SRDATAB\)](#) register.

#### Diagram



#### Fields

| Field        | Function                                                                           |
|--------------|------------------------------------------------------------------------------------|
| 31-8<br>—    | Reserved                                                                           |
| 7-0<br>VALUE | Value<br>Represents the byte read from the controller (and written by the target). |

### 39.7.44 Controller Read Data Halfword (MRDATAH)

#### Offset

| Register | Offset |
|----------|--------|
| MRDATAH  | C8h    |

## Function

Allows reading a halfword (byte pair) written by the target after an SDR Read or DAA or DDR. This register is only used when using [Controller Control \(MCTRL\)](#) to start the message. If MWMSG\_SDR or MWMSG\_DDR is used to start a message, that interface must be used exclusively.

A halfword should not be read unless there are at least two bytes of data waiting, as indicated the Receive FIFO level trigger or [MDATACTRL\[RXCOUNT\]](#).

## Diagram

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

## Fields

| Field       | Function                                                                                |
|-------------|-----------------------------------------------------------------------------------------|
| 31-16<br>—  | Reserved                                                                                |
| 15-8<br>MSB | MSB<br>Represents the second byte read from the controller (and written by the target). |
| 7-0<br>LSB  | LSB<br>Represents the first byte read from the controller (and written by the target).  |

## 39.7.45 Controller Write Byte Data 1(to bus) (MWDATAB1)

### Offset

| Register | Offset |
|----------|--------|
| MWDATAB1 | CCh    |

### Function

Allows writing bytes to send onto the bus, and is intended for DMAs which do not clear the upper bits of the word. It does not have the END bits. This register is only used when using [Controller Control \(MCTRL\)](#) to start the message. If MWMSG\_SDR or MWMSG\_DDR is used to start a message, that interface must be used exclusively.

**Diagram**

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

**Fields**

| Field        | Function                                                                                                          |
|--------------|-------------------------------------------------------------------------------------------------------------------|
| 31-8<br>—    | Reserved                                                                                                          |
| 7-0<br>VALUE | Value<br>Represents byte to write out. The block computes the parity for I3C, or manages the ACK or NACK for I2C. |

**39.7.46 Controller Write Halfword Data (to bus) (MWDATAH1)****Offset**

| Register | Offset |
|----------|--------|
| MWDATAH1 | CCh    |

**Function**

MWDATAH1 shares the same address as MWDATAB1. MDMACTRL[DMAWIDTH] determines which one is set.

MWDATAH1 allows writing a byte pair (halfword) to send onto the bus, and is intended for DMAs which do not clear the upper bits of the word. It does not have the END bits. This register is only used when using [Controller Control \(MCTRL\)](#) to start the message. If MWMSG\_SDR or MWMSG\_DDR is used to start a message, that interface must be used exclusively.

**Diagram**

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

**Fields**

| Field         | Function                                                                                                          |
|---------------|-------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—    | Reserved                                                                                                          |
| 15-0<br>VALUE | Value<br>Represents byte to write out. The block computes the parity for I3C, or manages the ACK or NACK for I2C. |

**39.7.47 Controller Write Message Control in SDR mode (MWMSG\_SDR\_CONTROL)****Offset**

| Register              | Offset |
|-----------------------|--------|
| MWMSG_SDR CONTR<br>OL | D0h    |

**Function**

Allows setting up and writing 16-bit words in Single Data Rate (SDR) mode. The MWMSG\_SDR\_ register is modal and has two modes: control and data.

- For the first write to set up a new message, this register functions as the MWSMSG\_SDR\_CONTROL register.
- For subsequent writes, this register functions as the [MWMSG\\_SDR\\_DATA](#) register.
- The control information is not pipelined. Write control information registers for a start and then again only when the data to be sent is done.

When not in the middle of a message, the MWMSG\_SDR\_CONTROL register is used to start a new message (or emit a STOP). After starting a message, the MWMSG\_SDR\_DATA register is used until the Length (see LEN field) counts down, or until data with END = 1 is used.

The MWMSG\_SDR\_CONTROL register is written with the 16-bit control word if currently stopped or after the end of the previous message. If [MSTATUS\[STATE\]](#) = 2 (MSGSDR) and [MSTATUS\[BETWEEN\]](#) = 0, the register (at this offset address) functions as the MWMSG\_SDR\_DATA register. Otherwise, this register (at this offset address) functions as the MWMSG\_SDR\_CONTRL register, as long as MSTATUS[STATE] is not in another mode.

The control word contains the byte length (6-bit), the address, the direction, and how it ends (stop, ready for next, continuation with more length). If the command is START and an event (IBI, CR, HJ) occurs, [MCTRL\[IBIRESP\]](#) is used to determine action, and the corresponding interrupt will occur. In that case, the message is restarted.

The MWMSG\_SDR\_CONTROL and MWMSG\_SDR\_DATA registers are oriented to DMA operations, but the MWMSG\_SDR\_CONTROL register can also be written by the processor (instead of using MCTRL and MxDATAB).

### Diagram

| Bits  | 31 | 30 | 29 | 28  | 27 | 26  | 25 | 24  | 23 | 22 | 21 | 20 | 19   | 18 | 17 | 16  |
|-------|----|----|----|-----|----|-----|----|-----|----|----|----|----|------|----|----|-----|
| R     |    |    |    |     |    |     |    |     | 0  |    |    |    |      |    |    |     |
| W     |    |    |    |     |    |     |    |     |    |    |    |    |      |    |    |     |
| Reset | u  | u  | u  | u   | u  | u   | u  | u   | u  | u  | u  | u  | u    | u  | u  | u   |
| Bits  | 15 | 14 | 13 | 12  | 11 | 10  | 9  | 8   | 7  | 6  | 5  | 4  | 3    | 2  | 1  | 0   |
| R     |    |    |    |     |    |     | 0  |     |    |    |    |    |      |    |    |     |
| W     |    |    |    | LEN |    | I2C |    | END |    |    |    |    | ADDR |    |    | DIR |
| Reset | u  | u  | u  | u   | u  | u   | u  | u   | u  | u  | u  | u  | u    | u  | u  | u   |

### Fields

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15-11<br>LEN | Length<br>Indicates the byte length of the message. If LEN = 0, then only END is used (and it will not use the address if Stopped). LEN = 1 must not be used. The minimal LEN size is 2 bytes (LEN = 2).                                                                                                                                                                                                                                                                    |
| 10<br>I2C    | I2C<br>Specifies whether the message is I2C or I3C.<br>0b - I3C message<br>1b - I2C message                                                                                                                                                                                                                                                                                                                                                                                 |
| 9<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 8<br>END     | End of SDR Message<br>Indicates end of SDR message. <a href="#">MSTATUS[COMPLETE]</a> = 1 when done. The end can happen: <ul style="list-style-type: none"><li>Before LEN bytes are read in I3C mode, if a target ends sooner.</li><li>Before LEN bytes are written in I2C mode, if a target NACKs.<br/>0b - Not the end. SDR message ends waiting for a new SDR message (issues a repeated START for a new message).<br/>1b - End. SDR message ends at the STOP.</li></ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                   |
|-------------|--------------------------------------------|
| 7-1<br>ADDR | Address<br>Contains address to be written. |
| 0<br>DIR    | Direction<br>0b - Write<br>1b - Read       |

### 39.7.48 Controller Write Message Data in SDR mode (MWMSG\_SDR\_DATA)

#### Offset

| Register       | Offset |
|----------------|--------|
| MWMSG_SDR_DATA | D0h    |

#### Function

Contains the 16-bit word to be written in Single Data Rate (SDR) mode. This register also functions as the [MWMSG\\_SDR\\_CONTROL](#) register.

#### Diagram

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

#### Fields

| Field      | Function |
|------------|----------|
| 31-17<br>— | Reserved |
| 16<br>—    | Reserved |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function |
|-----------------|----------|
| 15-0<br>DATA16B | Data     |

### 39.7.49 Controller Read Message in SDR mode (MRMSG\_SDR)

#### Offset

| Register  | Offset |
|-----------|--------|
| MRMSG_SDR | D4h    |

#### Function

Allows reading 16-bit words from a target in SDR message mode. The MRMSG\_SDR register is used to read 16-bit words from an active message started with MWMSG\_SDR. These words are intended to be read by DMA.

#### Diagram



#### Fields

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                      |
| 15-0<br>DATA | <p>Data</p> <p>Contains the 16-bit word read from the target.</p> <ul style="list-style-type: none"> <li>If the length (LEN) was an odd number, the upper byte is 0.</li> <li>If the target ends before LEN is finished, the module treats the read as completed.</li> <li>If the target is not done before LEN is finished and END is not a continuation, the read is terminated.</li> </ul> |

### 39.7.50 Controller Write Message in DDR mode: First Control Word (MWMSG\_DDR\_CONTROL)

#### Offset

| Register              | Offset |
|-----------------------|--------|
| MWMSG_DDR CONTR<br>OL | D8h    |

#### Function

Allows setting up and writing 16-bit words in Double Data Rate (DDR) mode. The register has three modes.

- The first write to set up a new message, functions as the MWMSG\_DDR\_CONTROL register.
- The second write contains the functions as shown in the MWMSG\_DDR\_CONTROL2 register.
- For subsequent writes, this register functions as the MWMSG\_DDR\_DATA register.
- The control information is not pipelined. Write control information registers at the start and then again only once the data to be sent is done.

When not in the middle of a message, the MWMSG\_DDR\_CONTROL register is used to start a new message (or emit a STOP). After starting a message, the MWMSG\_DDR\_DATA register is used until the Length (see LEN field) counts down or until data with END = 1 is used.

The MWMSG\_DDR\_CONTROL register is written with the 16-bit Control word if currently stopped or after the end of the previous message. If **MSTATUS[STATE]** = 4 (MSGDDR) and **MSTATUS[BETWEEN]** = 0, then the register (at this offset address) functions as the MWMSG\_DDR\_DATA register. Otherwise, this register (at this offset address) functions as the MWMSG\_DDR\_CONTROL register, as long as **MSTATUS[STATE]** is not in another mode.

The main control word contains the 16-bit word length and how it ends (stop, ready for next, continuation with more length). Then the command word contains the command and address for read or write. If the command is START and an event (IBI, CR, HJ) occurs, **MCTRL[IBIRESP]** is used to determine action, and the corresponding interrupt will occur. In that case, the message is restarted.

#### NOTE

The module handles preamble, parity, and CRC.

The MWMSG\_DDR\_CONTROL, MWMSG\_DDR\_CONTROL2, and MWMSG\_DDR\_DATA registers are oriented to DMA operations, but the MWMSG\_DDR\_CONTROL register can also be written by the processor (instead of using MCTRL and MxDATAB).

#### Diagram



**Fields**

| Field           | Function                                                                                                                                                                                                                                                                                                                          |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—      | Reserved                                                                                                                                                                                                                                                                                                                          |
| 15-0<br>ADDRCMD | <p>Address Command</p> <p>First Data write after control write with LEN!=0. This is formatted as:</p> <ul style="list-style-type: none"> <li>• 15:9 Target Address to read or write.</li> <li>• 8 Reserved, should be 0.</li> <li>• 7 1 if Read, 0 if Write.</li> <li>• 6:0 CMD as 7-bit value, always for controller.</li> </ul> |

**39.7.51 Controller Write Message in DDR mode Control 2 (MWMSG\_DDR\_CONTROL2)****Offset**

| Register               | Offset |
|------------------------|--------|
| MWMSG_DDR CONTR<br>OL2 | D8h    |

**Function**

Contains the 2nd Control word instructions with length of message and end.

**Diagram****Fields**

| Field      | Function |
|------------|----------|
| 31-16<br>— | Reserved |
| —          |          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                |
| 14<br>END  | <p>End of message</p> <p>Indicates end of DDR message. <a href="#">MSTATUS[COMPLETE]</a> = 1 when done. The end can happen before LEN bytes are read if the target ends sooner.</p> <p>0b - Not the end. DDR message ends waiting for a new DDR message (will issue a HDR Restart for the new message).</p> <p>1b - End. DDR message ends on HDR Exit.</p>                                                              |
| 13-10<br>— | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                |
| 9-0<br>LEN | <p>Length of Message</p> <p>Contains the length of the message (including the command) in halfwords, up to 2046 bytes. If LEN = 0, then END is applied only.</p> <ul style="list-style-type: none"> <li>For reads, + 1 for the CRC. For example, to read 4 bytes (2 halfwords), use 1 + 2 + 1 for CMD + 2 halfwords + CRC.</li> <li>For writes, LEN is the number of halves of data bytes + 1 (for command).</li> </ul> |

### 39.7.52 Controller Write Message Data in DDR mode (MWMSG\_DDR\_DATA)

#### Offset

| Register       | Offset |
|----------------|--------|
| MWMSG_DDR_DATA | D8h    |

#### Function

Contains the 16-bit word to be written in Double Data Rate (DDR) mode. This register also functions as the [MWMSG\\_DDR\\_CONTROL](#) register.

**Diagram**

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

**Fields**

| Field   | Function |
|---------|----------|
| 31-17   | Reserved |
| —       |          |
| 16      | Reserved |
| —       |          |
| 15-0    | Data     |
| DATA16B |          |

**39.7.53 Controller Read Message in DDR mode (MRMSG\_DDR)****Offset**

| Register  | Offset |
|-----------|--------|
| MRMSG_DDR | DCh    |

**Function**

Allows reading 16-bit words from a target in Double Data Rate (DDR) message mode from an active message started with MWMSG\_DDR. These words are intended to be read by DMA.

**Diagram**

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

**Fields**

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>—   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 15-0<br>DATA | <p>Data</p> <p>Contains the 16-bit word read from a target. The first byte is the LSB, and is in DATA[7:0]. The second byte is the MSB, and is in DATA[15:8].</p> <ul style="list-style-type: none"> <li>If the target ends before the entire length of the message (MWMSG_DDR[LEN]) is read, the module considers the DATA read as completed. In I3C mode, the target can indicate the end of message (the last byte). Otherwise, the controller terminates the message if the message is more than the controller will accept.</li> <li>If the target has not yet finished sending DATA before the entire length of the message (MWMSG_DDR[LEN]) is read and END is not a continuation, the DATA read will be terminated.</li> </ul> |

**39.7.54 Controller Dynamic Address (MDYNADDR)****Offset**

| Register | Offset |
|----------|--------|
| MDYNADDR | E4h    |

**Function**

Allows an I3C module to write its own Dynamic Address (DA) when the I3C module changes from Controller mode to Target mode.

If this device is the Main Controller (the controller during bus initialization), then this device may use this mechanism to assign itself its DA. When the device hands off control to a secondary controller, it becomes a target itself. This DA must be written before switching to Target mode and must not be changed once in Target mode (it is not clock-safe to do so). It must be written with a valid address value in DADDR if DAVALID = 1.

**NOTE**

The Main Controller also uses DEFSLVS CCC to define the target addresses, including itself; this mechanism is how secondary controllers know this address. If the controller is not the Main Controller, then this mechanism should not be used.

**Diagram**

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

**Fields**

| Field        | Function                                                                     |
|--------------|------------------------------------------------------------------------------|
| 31-8         | Reserved                                                                     |
| —            |                                                                              |
| 7-1<br>DADDR | Dynamic address<br>Contains the assigned Dynamic Address when DAVALID = 1.   |
| 0<br>DAVALID | Dynamic address valid<br>0b - No valid DA assigned<br>1b - Valid DA assigned |

**39.7.55 Map Feature Control 0 (SMAPCTRL0)****Offset**

| Register  | Offset |
|-----------|--------|
| SMAPCTRL0 | 11Ch   |

**Function**

The SMAPCTRLn registers are named SMAPCTRL0, SMAPCTRL1, and so on based on the number of mapped addresses. MAPCTRL0 represents the Primary DA or SA with SMAPCTRL1 onwards being the Mapped addresses.

The features of the SMAPCTRLn registers depend on configurations. SMAPCTRL0 acts differently, as shown below.

In general, this mechanism is intended to replace the DYNADDR register for all MAP related uses.

When using the Auto-MAP and DASA or AASA, the slot is changed from SA to DA. If the controller then issues RSTDAA, the application must rewrite the static addresses and enable them, as they will be marked disabled.

### Diagram

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

### Fields

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-17<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 16<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 15-11<br>—    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 10-8<br>CAUSE | <p>Cause</p> <p>Indicates the cause of the most recent DA assignment, which caused a <a href="#">SSTATUS[DACHG]</a> interrupt.</p> <p>With MAP enabled.</p> <ul style="list-style-type: none"> <li>000b - No information. This value occurs when not configured to write DA.</li> <li>001b - Set using ENTDA</li> <li>010b - Set using SETDASA, SETAASA, or SETNEWDA</li> <li>011b - Cleared using RSTDAA</li> </ul> <p>100b - Auto MAP change happened last. The change may have changed this DA as well (for example, ENTDA, and SETAASA), but at least one MAP entry automatically changed after.</p> <p>All other values are reserved.</p> |
| 7-1<br>DA     | <p>Dynamic Address</p> <p>Contains primary DA when ENA = 1. When ENA = 0, static address is used (but not shown here).</p> <p>With MAP enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0             | Enable Primary Dynamic Address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                         |
|-------|--------------------------------------------------|
| ENA   | With MAP enabled.<br>0b - Disable<br>1b - Enable |

### 39.7.56 Extended IBI Data 1 (IBIEXT1)

#### Offset

| Register | Offset |
|----------|--------|
| IBIEXT1  | 140h   |

#### Function

Contains extended IBI data.

The CTRL register is used to submit IBI, CR, and Hot-Join when enabled to do so. If allowed, an IBI may have additional bytes following the Mandatory Data byte (MDB). Extended IBI data is allowed when [SCTRL\[EXTDATA\]](#) = 1. If allowed, the extra bytes are indicated using these two registers.

#### Diagram



#### Fields

| Field | Function                   |
|-------|----------------------------|
| 31-24 | Extra byte 3               |
| EXT3  | Contains third extra byte  |
| 23-16 | Extra byte 2               |
| EXT2  | Contains second extra byte |
| 15-8  | Extra byte 1               |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                     |
|------------|----------------------------------------------------------------------------------------------|
| EXT1       | Contains first extra byte                                                                    |
| 7<br>—     | Reserved                                                                                     |
| 6-4<br>MAX | Maximum<br>Indicates the maximum number of extra bytes allowed by configuration. 0, if none. |
| 3<br>—     | Reserved                                                                                     |
| 2-0<br>CNT | Count<br>Contains the number of extra bytes beyond the MDB to be used. 0, if none.           |

### 39.7.57 Extended IBI Data 2 (IBIEXT2)

#### Offset

| Register | Offset |
|----------|--------|
| IBIEXT2  | 144h   |

#### Function

Contains extended IBI data.

The CTRL register is used to submit IBI, CR, and Hot-Join when enabled to do so. If allowed, an IBI may have additional bytes following the Mandatory Data byte (MDB). Extended IBI data is allowed when [SCTRL\[EXTDATA\]](#) = 1. If allowed, the extra bytes are indicated using these two registers.

#### Diagram

|       |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |
|-------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------|
| Bits  | 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16   |
| R     | EXT7 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | EXT6 |
| W     |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |
| Reset | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    |
| Bits  | 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0    |
| R     | EXT5 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | EXT4 |
| W     |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |      |
| Reset | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    |

**Fields**

| Field | Function                    |
|-------|-----------------------------|
| 31-24 | Extra byte 7                |
| EXT7  | Contains seventh extra byte |
| 23-16 | Extra byte 6                |
| EXT6  | Contains sixth extra byte   |
| 15-8  | Extra byte 5                |
| EXT5  | Contains fifth extra byte   |
| 7-0   | Extra byte 4                |
| EXT4  | Contains extra byte         |

**39.7.58 Target Module ID (SID)****Offset**

| Register | Offset |
|----------|--------|
| SID      | FFCh   |

**Function**

The BlockID, if enabled, allows software to detect the module and its version information.

**Diagram****Fields**

| Field | Function                                                                  |
|-------|---------------------------------------------------------------------------|
| 31-0  | ID                                                                        |
| ID    | The ID meaning is specific to each use of the I3C module. ID = EDCB0100h. |

# Chapter 40

## Analog-to-Digital Converter (ADC)

### 40.1 Chip-specific ADC information

Table 238. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | ADC            | <a href="#">ADC</a>                 |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 40.1.1 Module instances

This device has one instance of 16-bit ADC: ADC0.

#### 40.1.2 ADC input connections

Table 239. ADC analog channel input connections

| ADC Channel (CMDLn[ADCH]) | ADC0 A Connection | Description                             |
|---------------------------|-------------------|-----------------------------------------|
| 0                         | ADC0_A0           | 40 Ohm                                  |
| 1                         | ADC0_A1           | 40 Ohm                                  |
| 2                         | ADC0_A2           | 40 Ohm                                  |
| 3                         | ADC0_A3           | 40 Ohm                                  |
| 4                         | ADC0_A4           | 40 Ohm                                  |
| 5                         | ADC0_A5           | 40 Ohm                                  |
| 6                         | ADC0_A6           | 40 Ohm                                  |
| 7                         | ADC0_A7/VREFI     | 300 Ohm                                 |
| 8                         | ADC0_A8           | This ADC channels comes through I/O mux |
| 9                         | ADC0_A9           | This ADC channels comes through I/O mux |
| 10                        | ADC0_A10          | This ADC channels comes through I/O mux |
| 11                        | ADC0_A11          | This ADC channels comes through I/O mux |
| 12                        | ADC0_A12          | This ADC channels comes through I/O mux |

*Table continues on the next page...*

Table 239. ADC analog channel input connections (continued)

|    |              |                                              |
|----|--------------|----------------------------------------------|
| 13 | ADC0_A13     | This ADC channels comes through I/O mux      |
| 14 | ADC0_A14     | This ADC channels comes through I/O mux      |
| 15 | ADC0_A15     | This ADC channels comes through I/O mux      |
| 16 | ADC0_A16     | This ADC channels comes through I/O mux      |
| 17 | ADC0_A17     | This ADC channels comes through I/O mux      |
| 18 | ADC0_A18     | This ADC channels comes through I/O mux      |
| 19 | ADC0_A19     | This ADC channels comes through I/O mux      |
| 20 | ADC0_A20     | This ADC channels comes through I/O mux      |
| 21 | ADC0_A21     | This ADC channels comes through I/O mux      |
| 22 | ADC0_A22     | This ADC channels comes through I/O mux      |
| 23 | ADC0_A23     | This ADC channels comes through I/O mux      |
| 24 | Reserved     | -                                            |
| 25 | Reserved     | -                                            |
| 26 | Temperature+ | Internal                                     |
| 27 | PMC BG+      | ADC Internal PMC Bandgap, pmc_1vbuf_ana_1p8v |
| 28 | Reserved     | -                                            |
| 29 | VDD/ 4       | Internal                                     |
| 30 | Reserved     | -                                            |
| 31 | Reserved     | -                                            |

#### 40.1.3 ADC voltage reference options

The ADC voltage references can be selected by CFG[REFSEL] as follows:

- CFG[REFSEL]=00, VREFH reference pin
- CFG[REFSEL]=01, VREFI
- CFG[REFSEL]=10, VDD\_ANA supply pin

#### 40.1.4 ADC trigger inputs

ADC trigger sources get routed through the Input Multiplexing (INPUTMUX). See the [INPUTMUX](#) chapter for available trigger sources.

### 40.2 Overview

16-bit ADC is a successive approximation ADC designed for operation within an integrated microcontroller system-on-chip.

**NOTE**

For the chip specific modes of operation, see the power management information of the device.

#### 40.2.1 Block diagram

The following figure is the ADC module block diagram.



Figure 174. ADC block diagram

#### 40.2.2 Features

Following are the features of the ADC module.

- Linear successive approximation algorithm
  - single-ended operation with 16-bit or 12-bit resolution
- Configurable analog input sample time
- Configurable speed options to accommodate operation in low power modes of SoC
- Trigger detect with up to 4 trigger sources with priority level configuration. Software or hardware trigger option for each.
- 7 command buffers allow independent options selection and channel sequence scanning.

- Automatic compare for less-than, greater-than, within range, or out-of-range with "store on true" and "repeat until true" options
- 8-entry conversion result data FIFO with configurable watermark and overflow detection
- Interrupt, DMA or polled operation
- Linearity and gain adjustment calibration logic

## 40.3 Functional description

The ADC module performs analog-to-digital conversions on any of the software selectable analog input channels by a successive approximation algorithm. The module initializes to its lowest power state during reset. The ADC analog circuits can optionally be pre-enabled for faster starts to conversions at the expense of higher idle currents. Conversions are initiated by selectable trigger events from software or hardware sources. The trigger detect logic includes a configurable enable and priority scheme for the available trigger sources. The module includes multiple command buffers that provide configurable flexibility for channel scanning and independent channel selections for different trigger sources. Multiple command buffers also allow variable option selection such as sample time and averaging on a per-channel basis.

The ADC module optionally averages the result of multiple conversions on a channel before storing the calculated result. The hardware average function is enabled by setting CMDH<sub>6</sub>[AVGS] bitfield to a non-zero value and operates in any of the conversion modes and configurations.

When the conversion and averaging loops are completed, the resulting data is placed in a FIFO data buffer along with other tag information associated with the result. A configurable watermark level supports interrupt or DMA requests when the number of stored datawords exceeds the setting. Interrupts can also be enabled to indicate when FIFO overflow errors occur.

The ADC module optionally compares the result of a conversion with the contents of two value registers for less-than, greater-than, inside-range or outside-range detection. The compare function operates in any of the conversion modes and configurations.

The ADC module includes offset and linearity calibration logic. A request for calibration should be made any time upon reset or power up. Each SAR conversion utilizes calibration data calculated during the calibration routine.

The sequencing of a ADC command is summarized in the flow diagram shown below.



#### 40.3.1 Power control mode

By default, the ADC analog circuits are disabled while ADC is in its idle state. When a trigger is detected and ADC command processing is initiated, the analog circuits are enabled. These circuits require a period of initialization before the first conversion cycle.

The value of **CFG[PUDLY]** should be set to incur a delay longer than  $t_{ADCSTUP}$ . The accuracy of initial conversions after activation is degraded if the value of **CFG[PUDLY]** is too low.

You can achieve faster conversion startup times by setting **CFG[PWREN]** to pre-enable the analog circuits of ADC. This faster conversion consumes extra power, even while ADC is in an idle state. When **CFG[PWREN]** is 1, the Power Enable timer is

activated. The timer enforces the minimum time required (configured by CFG[PUDLY]) before detected triggers can initiate ADC conversions.

ADC also has options for controlling power and performance summarized in the table below. See the device data sheet for specification of the available power modes.

**Table 240. Power option settings**

| CFG[PWRSEL]  | Description               |
|--------------|---------------------------|
| 0b (Default) | Slow speed and low power  |
| 1b           | Fast speed and high power |

#### 40.3.2 ADC behavior in low power mode

The ADC module supports system level low power modes. In system low power modes where the ADC can remain functional, the CTRL[DOZEN] bit controls ADC behavior.

With the CTRL[DOZEN] bit clear, if the ADC was configured and enabled before low power mode entry, ADC is allowed to continue operation while the system is transitioned to the low power state. Any conversion in progress is not disrupted. External hardware trigger detect and active conversions are operational.

With the CTRL[DOZEN] bit set the ADC waits for the current averaging iteration/FIFO storage to complete before acknowledging low power entry request. After system entry to the low power state, the ADC is kept in inactive state until the system exits the low power state.

When entering a low power mode where the ADC cannot remain functional, the CTRL[DOZEN] bit is ignored and the ADC always waits for the current averaging iteration/FIFO storage to complete before acknowledging the low power entry request. After entry to the low power state, the ADC is kept in an inactive state until the system exits the low power state. The CFG[PWREN] bit setting is ignored and the ADC analog is forced to its lowest power state. Upon wakeup from the low power state, if the analog was pre-enabled before stop mode entry (i.e., the CFG[PWREN] bit is set) and the control registers have retained state in the low power mode, the analog is automatically re-enabled and the power up delay timer begins. Any triggered conversion is stalled until the power up delay associated with the CFG[PUDLY] control field has finished.

#### 40.3.3 Voltage reference

The voltage reference high ( $V_{REFH}$ ) used by the ADC is supplied from either an on-chip voltage reference source or from an off-chip source supplied through external pins.  $V_{REFL}$  is always from an external pin and must be at the same voltage potential as  $V_{SSA}$ . See the chip configuration information on the voltage reference options specific to this packaged device.

This block supports a programmable selection of the Voltage Reference High used for ADC conversions (via the CFG[REFSEL] field). See the chip configuration information on the voltage reference options specific to this packaged device.

#### 40.3.4 Trigger detect and command execution

See [Figure 175](#) for a flow diagram of command execution sequencing.

ADC command execution is initiated from up to 4 trigger sources. Each trigger can be software generated by writing 0b1 to the corresponding SWTRIG[SWT $n$ ] bitfield. Alternatively, hardware triggers can be generated from asynchronous input sources at the periphery of the module. The number and sources of hardware triggers implemented is device specific. Refer to chip configuration information for description of available hardware trigger sources for this device.

Each hardware trigger source is enabled by setting the associated enable bit (TCTRLa[HTEN]). Each trigger source is assigned a priority via the associated priority control field (TCTRLa[TPRI]). Each of the trigger sources is associated with a command buffer via the associated command select field (TCTRLa[TCMD]).

When a hardware trigger input is enabled, hardware trigger events are detected on the rising-edge of the associated hardware trigger source.

When the ADC is inactive, achieving the minimum startup time to begin an initial conversion after a software or hardware generated trigger requires that the ADC be pre-enabled (by setting [CFG\[PWREN\]](#) during ADC initialization and allowing enough

time for ADC power-up delay to timeout before allowing any triggers to be generated). In the case of a pre-enabled ADC, it takes 9 ADCK cycles for the trigger to be recognized and begin sampling on the associated analog channel.

In the case that the ADC is not pre-enabled, an initial conversion is delayed further as determined by the power-up delay ([CFG\[PUDLY\]](#)). Conversion startup can also be delayed on a trigger source basis (TCTRLn[TDLY]).

Each trigger source has an associated priority field TCTRLa[TPRI] which allows for arbitration between trigger sources. Arbitration is in control of two things: selecting which trigger sequence to execute next, and selecting how to handle a trigger exception. Trigger exceptions are defined as allowing a higher priority trigger sequence to interrupt operation of a lower priority sequence. When a trigger exception occurs, programmable arbitration allows the configurable stop and resume points for low priority sequences. The fields affecting arbitration are CFG[HPT\_EXDI], CFG[TCMDRES], CFG[TRES], and CFG[TPRICTRL].

1. If CFG[HPT\_EXDI] is set to 1'b1 then trigger exceptions are disabled and any higher priority triggers are left pending until the current sequence completes. Note that new triggers are accepted based on priority.
2. If CFG[HPT\_EXDI] is set to 1'b0 (default), then exceptions are enabled and the higher priority sequence begins executing at a user specified breakpoint.

Breakpoint locations are determined by the register CFG[TPRICTRL]. CFG[TPRICTRL] has an affect on latency for accepting a trigger exception.

1. When CFG[TPRICTRL]=0x0, a higher priority trigger causes an immediate command abort and the new command specified by the trigger is immediately started. It takes 9 ADCK cycles for the higher priority trigger to be recognized, terminate the conversion in progress, and complete a switch to the new associated ADC command. 9 ADCK cycles after the trigger is driven to the ADC, the ADC begins sampling on the associated new analog channel.
2. When CFG[TPRICTRL]=0x1, the current conversion is allowed to complete (including averaging) before the higher priority exception is initiated. In this mode, if the command is running through a series of averages, this series completes. However, there is no requirement to finish the entire command before being interrupted. For example, if the command consists of 4 loop iterations, there is no requirement to complete all 4 iterations before the interrupt occurs.
3. When CFG[TPRICTRL]=0x2, a higher priority trigger begins once the current command is completed. If a command consists of 5 loop iterations each containing 8 averages, then all 5x8 conversions must be completed before accepting the trigger exception.

CFG[TCMDRES] and CFG[TRES] determine what the ADC does after accepting a trigger exception. The module can be programmed to resume commands after returning from a trigger exception.

1. If CFG[TRES] = 0x0 then commands are not automatically resumed after being stopped by an exception. However, an interrupt is set to indicate this case has occurred. The flag TSTAT[TEXC\_NUM] can be used to resolve which trigger was stopped by the exception.
2. If CFG[TRES] = 0x1 the ADC automatically resumes commands after they were stopped by an exception.

By utilizing CFG[TRES] in conjunction with CFG[TCMDRES], the module can be programmed to resume commands at one of two possible locations.

1. If CFG[TCMDRES] = 0x0 then the trigger which was stopped by an exception is resumed from the beginning of its associated command sequence. Note, triggers which are waiting to be resumed take the same priority programmed to TCTRLa[TPRI].
2. If CFG[TCMDRES] = 0x1 then the trigger is resumed from the command that it was executing before being interrupted by an exception.

If a lower priority trigger occurs (i.e., a trigger event occurs that is configured for a lower priority than the trigger source associated with the currently executing command), the trigger detect is left pending until completion of the current command sequence. Lower priority trigger events cannot be serviced until a higher priority triggered command (or command sequence) completes.

When a conversion is completed (including hardware averaging when CMDHa[AVGS] is non-zero), the result is placed in a RESFIFO buffer. When an ADC command selects looping (when CMDHa[LOOP] is non-zero) a command stores multiple conversion results to the FIFO during execution of that command.

At the end of command execution, the CMDHa[NEXT] field of the command selects the next command to be executed. Multiple commands can be executed sequentially by configuration of each commands CMDHa[NEXT] field. Setting the next command

to 0x0 causes conversions to terminate at the completion of the command. Unending circular command execution is allowed by setting the CMDHa[NEXT] field in the last command in a sequence to the first command in the sequence.

By default, command sequences executes automatically in the order that CMDHa[NEXT] fields are programmed. However, by utilizing the CMDHa[WAIT\_TRIG], command execution can be stalled and launched based on trigger inputs. For example, if TRIGGER2 is programmed to start the command sequence CMD1, CMD2, CMD3, then receiving TRIGGER 2 one time unconditionally runs this sequence to completion. If CMDH2[WAIT\_TRIG] is set to 0x1, however, then the sequence pauses after CMD1 until TRIGGER2 is received again. Therefore, sequences can be stalled until receiving a trigger assertion.

Disabling the ADC by writing 0b0 to the CTRL[ADCEN] bitfield terminates any active ADC command processing. Writing 0b0 to the CTRL[ADCEN] bitfield causes the current command (or command sequence) to terminate, clears any pending triggers and sends the ADC module to an IDLE state.

#### 40.3.5 Pause option

When the maximum conversion rate is not required by an application the effective conversion rate can be reduced by implementing periodic trigger events to initiate ADC conversions or by selecting a reduced frequency clock as the ADACK source. Both of these options are chip specific and are dependent on ADC triggering and clocking options external to the ADC module. The latency associated with ADC analog power up delays results in a limit on the maximum conversion rate when using periodic triggering.

Another means of reducing conversion rates is by inserting a pause of a programmable duration between LOOP iterations, between commands in a sequence, and between conversions when command is executing in the "Compare Until True" configuration. When PAUSE[PAUSEEN] is set, the PAUSE[PAUSEDLY] field controls the duration of pausing during command execution sequencing. The pause delay is a count of (PAUSE[PAUSEDLY]\*4) ADCK cycles. Note, the PAUSE register should not be changed while the CTRL[ADCEN] bit is set. Writes to the PAUSE register while CTRL[ADCEN] is set can lead to metastable operation.

See [Figure 175](#) for the places during command execution sequencing where the pause is optionally inserted.

#### 40.3.6 Resync functionality

Any trigger source (SW or HW) can be configured to act as a resync trigger. Trigger based resync functionality is used to interrupt a running trigger (resync target) and clear the FIFO it's writing to. This can either be used to abort a running sequence, or restart a running sequence depending on the configuration of CFG[TRES]. If CFG[TRES] = 0b1 then the target sequence is aborted, the FIFO cleared, and the sequence restarted after the resync occurs. If CFG[TRES] = 0b0 then the target sequence is aborted and the FIFO is cleared after the RESYNC occurs.

A resync trigger needs to have a specific target. The resync only occurs if the resync target is running at the time of the trigger. For the following description, let n be the resync trigger number, let m be the resync target number. According to these variables, trigger n should resync trigger m. To enable a trigger source to act as a resync trigger, the following conditions must be satisfied:

1. The resync trigger TCTRLn[RSYNC] must be set to 0b1.
2. The resync trigger must have higher priority than the resync target (TCTRLn[TPRI] must be less than TCTRLm[TPRI]).
3. The resync target is specified using TCTRLn[TCMD]. In this case the resync target, m, must be equal to TCTRLn[TCMD].
4. The resync target, m, must be executing commands when the resync trigger, n, is asserted.
5. Trigger m must have at least one conversion left to begin when trigger n is received.

If a trigger source n has TCTRLn[RSYNC] set to 0b1, but some of the above conditions are not met then the trigger source n is ignored.

The following figure illustrates a resync trigger sequence executing. Note, in this example, trigger source 1 is configured to resync trigger source 0.



Figure 176. ADC Resync Example

In this figure, trigger source 0 was executing a sequence of commands when trigger source 1 was asserted. Notice that trigger source 0 is stopped when trigger source 1 is asserted (after some synchronization delay). In addition, the FIFO being written to by trigger source 0 is cleared (FIFO0 in this example). After the trigger 0 sequence is stopped, the ADC runs the next trigger pending with the highest priority. This is marked as NXT, for next trigger. If resume functionality is enabled, and trigger source 0 had the highest priority pending, then NXT = 0x00.

#### 40.3.7 Temperature sensor

The ADC module has a dedicated input channel for an on-chip temperature sensor. Refer to the chip specific channel definition to determine which channel is connected to the on-chip temperature sensor.

To calculate the temperature, application software must first execute a conversion of the temperature sensor channel with some configuration requirements. This sequence for converting the temperature sensor channel is outlined below:

1. Refer to chip specific channel definition to determine which channel corresponds to the temperature sensor.
2. Configure a command buffer register to convert the temperature sensor channel. CMDLa[ADCH] = Temperature Sensor Channel.
3. The command buffer must also be programmed with the following parameters:
  - 16b mode (CMDLa[MODE] = 0x1)
  - Max averaging (CMDHa[AVGS] = 0xA)
  - Max sample time (CMDHa[STS] = 0x7)
  - LOOP set to 1 (CMDHa[LOOP] = 0x1)
  - Loop with increment disabled (CMDHa[LWI] = 0x0)
  - Compare function disabled (CMDHa[CMPEN] = 0x0)
4. Configure a trigger control register TCTRLa with the following parameters:

- TCTRLa[TCMD] = command buffer used in steps 2 and 3.
5. Trigger a conversion of the temperature sensor channel. Software triggers the conversion by writing "1" to the associated bit in SWTRIG register (i.e., the trigger configured in step 4).

After completion of the conversion of the temperature sensor channel, two results are stored in the FIFO. Each result corresponds to a component of the overall temperature value. Application software reads these values from the FIFO and uses the equation below to calculate the ambient temperature.

$$\text{Temp} = A \left[ \frac{\alpha(V_{be8} - V_{be1})}{V_{be8} + (\alpha(V_{be8} - V_{be1}))} \right] - B$$

**Equation 2. Temperature sensor function**

Where:

- $V_{be1}$  is the first value stored to the FIFO as a result of the temperature sensor channel conversion
- $V_{be8}$  is the second value stored to the FIFO as a result of the temperature sensor channel conversion
- $A$  is the slope factor
- $B$  is the offset factor
- $\alpha$  is the bandgap coefficient

$A$ ,  $B$ , and  $\alpha$  are specified constant values from the ADC Electrical information in the device datasheet.

#### 40.3.8 Result FIFO operation

The ADC includes 1 8 entry FIFOs in which the result of ADC conversions are stored. In addition, a valid indicator bit, the trigger source, the source command and the loop count are also stored along with the data. FCTRLa[FCOUNT] indicates how many valid datawords are stored in each RESFIFO.

A programmable watermark threshold supports configurable notification of data availability. When FCTRLa[FCOUNT] is greater than FCTRLa[FWMARK], the associated RDY flag is asserted. When IE[FWMIE<sub>x</sub>] is set, a watermark interrupt request is issued. When DE[FWMDE<sub>x</sub>] is set, a DMA request is issued. Reading RESFIFO provides the oldest unread dataword entry in the FIFO and decrements FCTRLa[FCOUNT]. When FCTRLa[FCOUNT] falls equal to or below FCTRLa[FWMARK], the RDY flag is cleared.

Each FIFO can be emptied by successive reads of RESFIFOa. When the RESFIFOa[VALID] bit is 1 the associated FIFO entry is valid. Reading RESFIFOa when the FIFO is empty (when RESFIFOa[VALID] is clear and FCTRLa[FCOUNT]=0x0) provides an undefined dataword. All FIFOs are reset by writing 0b1 to the CTRL[RSTFIFO<sub>x</sub>] bit.

If the ADC attempts to store a dataword to the FIFO when the FIFO is full the FIFO overflow flag (FCTRLa[FOF]) is set. When IE[FOFIE<sub>x</sub>] is set, a overflow interrupt request is issued. The FOF flag is cleared by writing 1 to STAT[FOFx]. On overflow events no new data is stored and the data associated with the store that triggered the overflow is lost.

#### 40.3.9 Compare function

After the input is sampled and converted and any averaging iterations are performed, the CMDHa[CMPEN] field guides operation of the automatic compare function to optionally only store when the compare operation is true. There are multiple options on command sequencing related to the compare function as summarized in the table below.

##### NOTE

Latency is added to the end of a compare until true conversion to resolve the next command or loop in a sequence. This latency is necessary to calibrate the SAR data before resolving the result of a comparison. Delay for this feature is only added when resolving the result of a conversion. This means that intermediate samples during averaging do not include extra latency. Only loop and command boundaries experience this delay. The latency is always less than or equal to 5 ADC clock cycles.

**NOTE**

Not all Command Buffers have an associated Compare Value register. The compare function is only available on Command Buffers that have a corresponding Compare Value register.

**Table 241. Compare modes**

| CMDH <sub>a</sub> [CMPEN] | Compare Function          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------------------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0b00                      | Compare disabled          | Do not perform compare operation. Always store the conversion result to the FIFO.                                                                                                                                                                                                                                                                                                                                                                                                    |
| 0b01                      | Reserved                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0b10                      | Store on true             | Perform compare operation. Store conversion result to FIFO at end of averaging only if compare is true. If compare is false do not store the result to the FIFO. In either the true or false condition, the LOOP setting is considered and increments the LOOP counter before deciding whether the current command has completed or additional LOOP iterations are required.                                                                                                         |
| 0b11                      | Repeat compare until true | Perform compare operation. Store conversion result to FIFO at end of averaging only if compare is true. Once the true condition is found the LOOP setting is considered and increments the LOOP counter before deciding whether the current command has completed or additional LOOP iterations are required. If the compare is false do not store the result to the FIFO. The conversion is repeated without consideration of LOOP setting and does not increment the LOOP counter. |

Depending on CV<sub>a</sub>[CVH] and CV<sub>a</sub>[CVL] values programmed, the compare operation checks whether the result is less than, greater than, or if the result falls within or outside a range determined by two compare values. The compare values are used as described in the following table.

**Table 242. Compare operations**

| CV <sub>a</sub> [CVL] vs.<br>CV <sub>a</sub> [CVH]                                      | Operation                       | Description                                                                                                              |
|-----------------------------------------------------------------------------------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| set CV <sub>a</sub> [CVL] < CV <sub>a</sub> [CVH]                                       | Outside range<br>(General form) | Compare true if the result is less than CV <sub>a</sub> [CVL] value <b>OR</b> greater than CV <sub>a</sub> [CVH] value.  |
| set CV <sub>a</sub> [CVH] to max value<br>set CV <sub>a</sub> [CVL] to<br>compare point | Less than                       | Compare true if the result is less than CV <sub>a</sub> [CVL] value.                                                     |
| set CV <sub>a</sub> [CVL] to min value<br>set CV <sub>a</sub> [CVH] to<br>compare point | Greater than                    | Compare true if the result is greater than CV <sub>a</sub> [CVH] value.                                                  |
| set CV <sub>a</sub> [CVL] > CV <sub>a</sub> [CVH]                                       | Inside range                    | Compare true if the result is less than CV <sub>a</sub> [CVL] value <b>AND</b> greater than CV <sub>a</sub> [CVH] value. |

**NOTE**

In low power modes where the ADC continues to operate, the compare function can monitor the voltage and only wake the device when the compare condition is met.

#### 40.3.10 Cycles per conversion

The number of ADCK cycles needed to complete a conversion varies based on the selected resolution (CMDLa[MODE]), the sample time configured, and several other configuration options discussed below.

To calculate the cycle count, first, determine the Base Cycles Count from [Table 243](#). Next, add the Sample Time Adder based on CMDHa[STS] setting as summarized in [Table 244](#). If averaging is enabled (CMDHa[AVGS] does not equal to 0), then the total cycles (Base Cycles Count + Sample Time Adder) should be multiplied by the number of averages configured as summarized in [Table 245](#).

$$\text{CycleCount / Conversion} = [(\text{BaseCycleCount} + \text{SampleTimeAdder}) * \text{AverageMultiplier}]$$

**Equation 3. Cycle Count/Conversion**

Note that there is latency associated with trigger detection and starting an initial conversion. There is additional latency associated with offset and gain error adjustment of a raw conversion result and storage of a final result to the FIFO. Due to pipe-lining of conversions when looping or command chaining is configured, the next conversion is immediately started while a raw conversion result is being adjusted and stored and thus the conversion rate is maximized.

The base cycles per conversion is variable depending on CMDLa[MODE], CFG2[HS], CFG2[HSEXTRA], and CFG2[TUNE] settings as summarized in the following table.

**Table 243. Base cycles per conversion**

| CFG2[HS]<br>(default 0) | CFG2[HSEXTRA]<br>(default 0) | CFG2[TUNE]<br>(default 01) | Base ADCK cycles/conversion <sup>1</sup> |                           | Description   |
|-------------------------|------------------------------|----------------------------|------------------------------------------|---------------------------|---------------|
|                         |                              |                            | 16-bit<br>CMDLa[MODE] = 1                | 12-bit<br>CMDLa[MODE] = 0 |               |
| 0                       | X                            | 00                         | 24                                       | 20                        |               |
| 0                       | X                            | 01                         | 23                                       | 19                        | Reset default |
| 0                       | X                            | 10                         | 22                                       | 18 <sup>2</sup>           |               |
| 1                       | 0                            | 00                         | 21                                       | 17                        |               |
| 1                       | 0                            | 01                         | 20                                       | 16                        |               |
| 1                       | 0                            | 10                         | 19                                       | 15 <sup>2</sup>           |               |
| 1                       | 1                            | 00                         | 22                                       | 18                        |               |
| 1                       | 1                            | 01                         | 21                                       | 17                        |               |
| 1                       | 1                            | 10                         | 20                                       | 16 <sup>2</sup>           |               |

1. This cycle count includes min sample time of 3.5 ADCK cycles.

2. Setting CFG2[TUNE] to 10 in 12-bit mode can result in missing codes (i.e., some result codes may not be produced).

In addition to the base cycles per conversion, the configured sample time needs to be considered. The sample time adder is variable depending on CMDHa[STS] setting and is summarized in the following table:

**Table 244. Sample time cycle adder**

| CMDHa[STS]<br>(default 000) | Add ADCK cycles/conversion |
|-----------------------------|----------------------------|
| 000                         | 0                          |
| 001                         | 2                          |

*Table continues on the next page...*

Table 244. Sample time cycle adder (continued)

| CMDHa[STS]<br>(default 000) | Add ADCK cycles/conversion |
|-----------------------------|----------------------------|
| 010                         | 4                          |
| 011                         | 8                          |
| 100                         | 16                         |
| 101                         | 32                         |
| 110                         | 64                         |
| 111                         | 128                        |

Table 245. Averaging multiplier

| CMDHa[AVGS] (default 0000) | Averaging multiplier |
|----------------------------|----------------------|
| 0000                       | 1                    |
| 0001                       | 2                    |
| 0010                       | 4                    |
| 0011                       | 8                    |
| 0100                       | 16                   |
| 0101                       | 32                   |
| 0110                       | 64                   |
| 0111                       | 128                  |
| 1000                       | 256                  |
| 1001                       | 512                  |
| 1010                       | 1024                 |

#### 40.3.11 Clocking

ADC uses the ADCK clock input provided by an on-chip clock select block. It is used by the SAR conversion-control sequencing logic and the FIFO storage buffer. The ADCK frequency must be within the specified frequency range for ADCK, and varies based on [CFG\[PWRSEL\]](#). See the device data sheet for supported frequency ranges.

ADC continues operating in low-power mode as long as [CTRL\[DOZEN\]](#) = 0 and the on-chip clock select block supplies an ADCK clock source.

##### NOTE

When in low-power mode with [CTRL\[DOZEN\]](#) = 0, the bus clock can be shut off, and asynchronous interrupts and DMA requests can be configured. ADC continues processing commands and writing data to the internal FIFO.

ADC has four sources for asynchronous interrupts during low-power mode: watermark, FIFO overflow, TCOMP, and TEXC. To enable them, configure [IE\[FWMIE\]](#), [IE\[FOFIE\]](#), [IE\[TCOMP\\_IE\]](#), and [IE\[TEXC\\_IE\]](#) before entering low-power mode.

When [CTRL\[DOZEN\]](#) = 1 in low-power mode, ADC waits for the current averaging iteration or FIFO storage to complete before acknowledging the low-power mode entry. Any pending triggers are dropped when a low-power mode request is made in this mode. ADC is forced into its lowest-power setting after acknowledging the low-power mode request.

#### 40.3.12 Resets

Table 246. ADC Resets

| Reset source   | Description                                                                                                                                                                                    |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Chip reset     | The logic and registers for the ADC are reset to their default state on a chip reset.                                                                                                          |
| Software reset | The ADC implements a software reset bit in its Control Register. The <a href="#">CTRL[RST]</a> bit resets all logic and registers to their default state, except for the CTRL register itself. |
| FIFO reset     | The ADC implements write-only control that reset the FIFO0 ( <a href="#">CTRL[RSTFIFO0]</a> ). After a FIFO is reset, that FIFO is empty.                                                      |

#### 40.3.13 Interrupts and DMA requests

The ADC includes several sources for interrupts and/or DMA requests. The table below summarizes these sources.

A programmable watermark threshold supports configurable notification of data availability and can generate either an interrupt exception or a DMA request. When [FCTRLn\[COUNT\]](#) is greater than [FCTRLn\[FWMARK\]](#), the associated RDYn flag is asserted. Masking for this exception is controlled by the [IE\[FWMIEn\]](#) and [DE\[FWMDEn\]](#) control bits. When RDYn is asserted and mask control bit IE[FWMIEn] is set, a watermark interrupt request is issued. When RDYn is asserted and mask control bit DE[FWMDEn] is set, a DMA request is issued.

The other exception sources can only generate interrupts and do not have a DMA request option. Each of these sources has a mask control bit in the IE register and no corresponding bit in the DE register.

Table 247. ADC Interrupts and DMA Requests

| Status Register (STAT) |                             | Description                                                                                                                                                                        | Can generate |              |                   |
|------------------------|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|-------------------|
| Flag                   | Name                        |                                                                                                                                                                                    | Interrupt?   | DMA Request? | Low Power Wakeup? |
| RDYn                   | Result FIFO n Ready Flag    | Conversion result data is written to Result FIFO and has a watermark configurable trigger level to generate an exception request as controlled by <a href="#">FCTRLn[FWMARK]</a> . | Y            | Y            | Y                 |
| FOFn                   | Result FIFO n Overflow Flag | Attempts to store data to the FIFO when the FIFO is full is an error condition.                                                                                                    | Y            | N            | Y                 |
| TCOMP_INT              | Trigger Completion Flag     | A trigger sequence has been completed (all associated commands have been run).                                                                                                     | Y            | N            | Y                 |
| TEXC_INT               | High Priority Trigger Flag  | A high priority trigger exception has occurred.                                                                                                                                    | Y            | N            | Y                 |

#### 40.4 External signals

The ADC module supports analog channel inputs. ADC requires supply and ground connections.

Table 248. ADC signal descriptions

| Signal                   | Description                  | I/O |
|--------------------------|------------------------------|-----|
| V <sub>DDA</sub>         | Analog Power Supply          | I   |
| V <sub>SSA</sub>         | Analog Ground                | I   |
| CHnA - CH0A <sup>1</sup> | A-side Analog Channel Inputs | I   |

1. where n is the maximum channel number supported in the chip. See the chip-specific information for the number of channels supported on your device.

#### 40.4.1 Analog channel inputs (CHnA)

[CMDLn\[ADCH\]](#) and [CMDLn\[CTYPE\]](#) control selection of individual input channels. Each ADC command independently makes a channel and conversion type selection.

**NOTE**

Some input channels from on-chip sources, such as temperature sensors and reference voltage sources, may only be connected to individual instances of ADC. Some input channel options in the field-setting descriptions may not be available for your device. See chip-specific information for the channels supported on this device.

### 40.5 Initialization

#### 40.5.1 Calibration

The ADC module has multiple calibration functions that must be executed as part of ADC setup to achieve the specified accuracy. Calibration must be run after any reset and before a conversion is initiated. Prior to offset calibration or calibration, the user must configure the clock source and frequency of ADC for the clock source availability and needs of the application. ADC must be enabled ([CTRL\[ADCEN\]](#) = 1h) before a calibration function runs. If calibration is requested while the ADC is actively converting, that sequence completes before starting calibration.

Averaging multiple conversions can achieve improved accuracy during the calibration routines. It is recommended to set [CTRL\[CAL\\_AVGS\]](#) for minimum of 256 averaging during calibration steps. If the application uses ADC in a wide variety of configurations, the configuration for which the highest accuracy is required should be selected. Alternatively, multiple calibrations can be done for the different configurations.

##### 40.5.1.1 Offset calibration

The [Offset Trim Register \(OFSTRIM\)](#) register is used to trim for ADC comparator offset voltage. The ADC supports an offset calibration function in which the OFSTRIM register is automatically updated. Below are the steps for executing the function.

1. Configure for the desired averaging via [CTRL\[CAL\\_AVGS\]](#). The minimum recommended setting is for 256 averaging ([CTRL\[CAL\\_AVGS\]](#) set to 0x8 or greater).
2. Initiate Offset Calibration by setting [CTRL\[CALOFS\]](#).
3. Poll the [STAT\[CAL\\_RDY\]](#) flag. When [STAT\[CAL\\_RDY\]](#) is asserted, the offset calibration function has completed and the OFSTRIM register has updated.

##### 40.5.1.2 ADC Calibration

ADC includes hardware calibration logic in which the converter is calibrated for gain error and linearity error correction of the raw conversion result. The [GCR0\[GCALR\]](#) and CAL\_GAR registers control calibration for the A-side converter. The ADC supports a calibration function in which the CAL\_GAR registers are automatically updated. The calibration function also updates [GCC0\[GAIN\\_CAL\]](#) (associated with A-side calibration). For A-side calibration, a software calculation is required to derive GCR0[GCALR] from GCC0[GAIN\_CAL]. Below are the steps for completing calibration setup.

1. Execute [Offset calibration](#) steps. The [Offset Trim Register \(OFSTRIM\)](#) is used during calibration to trim for comparator offset voltage.
2. Configure for the desired averaging via [CTRL\[CAL\\_AVGS\]](#). The minimum recommended setting is for 256 averaging ([CTRL\[CAL\\_AVGS\]](#) set to 0x8 or greater).
3. Initiate the calibration routine by writing 1 to [CTRL\[CAL\\_REQ\]](#). [CTRL\[CAL\\_REQ\]](#) remains 1 until the CAL routine has been accepted by the ADC. After acceptance, [CTRL\[CAL\\_REQ\]](#) automatically becomes 0.
4. Poll the [GCR0\[RDY\]](#) flag. When it is asserted, the hardware controlled A-side calibration operation is complete and CAL\_GAR and [GCC0\[GAIN\\_CAL\]](#) registers are updated. The updated value in [GCC0\[GAIN\\_CAL\]](#) is needed for further software processing described in the following steps.

5. Read [GCC0\[GAIN\\_CAL\]](#) and store for use in the gain\_adjustment calculation.
6. Calculate the A-side gain\_adjustment =  $(131072)/(131072-GCC0[GAIN\_CAL])$ . GCC0[GAIN\_CAL] is a 16-bit signed value. This results in a floating point value between 0 and 2.
7. Convert the floating point value to its integer component (0 or 1) and its fractional component rounded to 16-bits. The integer value is stored to GCR0[GCALR[16]] and the fractional component is stored to GCR0[GCALR[15:0]]. Write this value to the [GCR0\[GCALR\]](#) register.
8. Once GCR0[GCALR] contains the result from the gain\_adjustment calculation, set the GCR0[RDY] flag to indicate it is valid.

After completing the steps above, the calibration sequence is complete and the [STAT\[CAL\\_RDY\]](#) flag is set. The STAT[CAL\_RDY] flag remains set until the user resets the system or requests a new calibration sequence.

When STAT[CAL\_RDY] is set, the ADC is configured to run in calibrated mode. Each conversion uses a combination of linearity and gain calibration results to correct SAR data. Calibration conversion latency is required to process each sample. However, due to the pipelined nature of data and control sequences, each conversion can still be initiated without experiencing this calibration delay.

#### 40.5.1.3 Calibration General A-Side Register valid ranges

The general calibration value registers CAL\_GARa have 33 registers in each array. The data in each register is a signed 16-bit value but has a variable range of possible values. The following table defines the valid range each register supports.

Table 249. Calibration General Registers Valid Values

| Element CAL_GxR[N] | Valid Range      |
|--------------------|------------------|
| N = 0x00, 0x20     | -1024 to +1023   |
| N = 0x01           | -2048 to +2047   |
| N = 0x02–0x03      | -4096 to +4095   |
| N = 0x04–0x07      | -8192 to +8191   |
| N = 0x08–0x0F      | -16384 to +16383 |
| N = 0x10–0x1F      | -32768 to +32767 |

These registers are typically updated automatically during the self calibration sequence. To reduce the latency associated with ADC setup, the CAL\_GxR values from a calibration sequence can be stored in non-volatile memory after an initial calibration and written to the CAL\_GxR registers via software prior to the first ADC conversion. If these registers are set to values not generated by the calibration function, the linearity error specifications may not be met. Note, these values can only be written in a single access, byte accesses are not supported.

#### 40.5.1.4 High speed calibration

The [High Speed Trim Register \(HSTRIM\)](#) register is used to trim for high speed mode conversions (when CFG2[HS] is set). The ADC supports a high speed calibration function in which the HSTRIM register is automatically updated. Below are the steps for executing the function.

1. Configure for the desired averaging via [CTRL\[CAL\\_AVGS\]](#). The minimum recommended setting is for 256 averaging (CTRL[CAL\_AVGS] set to 0x8 or greater).
2. Initiate High speed calibration by setting [CTRL\[CALHS\]](#).
3. Poll the [STAT\[CAL\\_RDY\]](#) flag. When STAT[CAL\_RDY] is asserted, the high speed calibration function has completed and the HSTRIM register has updated.

## 40.6 ADC register descriptions

This section describes the ADC registers.

### 40.6.1 ADC memory map

HSADC0 base address: 400A\_F000h

| Offset    | Register                                   | Width<br>(In bits) | Access | Reset value |
|-----------|--------------------------------------------|--------------------|--------|-------------|
| 0h        | Version ID Register (VERID)                | 32                 | R      | 0200_1409h  |
| 4h        | Parameter Register (PARAM)                 | 32                 | R      | 0707_0804h  |
| 10h       | Control Register (CTRL)                    | 32                 | RW     | 0000_0000h  |
| 14h       | Status Register (STAT)                     | 32                 | RW     | 0000_0000h  |
| 18h       | Interrupt Enable Register (IE)             | 32                 | RW     | 0000_0000h  |
| 1Ch       | DMA Enable Register (DE)                   | 32                 | RW     | 0000_0000h  |
| 20h       | Configuration Register (CFG)               | 32                 | RW     | 0080_0000h  |
| 24h       | Pause Register (PAUSE)                     | 32                 | RW     | 0000_0000h  |
| 34h       | Software Trigger Register (SWTRIG)         | 32                 | RW     | 0000_0000h  |
| 38h       | Trigger Status Register (TSTAT)            | 32                 | RW     | 0000_0000h  |
| 40h       | Offset Trim Register (OFSTRIM)             | 32                 | RW     | 0000_0000h  |
| 48h       | High Speed Trim Register (HSTRIM)          | 32                 | RW     | 0000_0000h  |
| A0h - ACh | Trigger Control Register (TCTRL0 - TCTRL3) | 32                 | RW     | 0000_0000h  |
| E0h       | FIFO Control Register (FCTRL0)             | 32                 | RW     | 0000_0000h  |
| F0h       | Gain Calibration Control (GCC0)            | 32                 | R      | 0000_0000h  |
| F8h       | Gain Calculation Result (GCR0)             | 32                 | RW     | 0001_0000h  |
| 100h      | Command Low Buffer Register (CMDL1)        | 32                 | RW     | 0000_0000h  |
| 104h      | Command High Buffer Register (CMDH1)       | 32                 | RW     | 0000_0000h  |
| 108h      | Command Low Buffer Register (CMDL2)        | 32                 | RW     | 0000_0000h  |
| 10Ch      | Command High Buffer Register (CMDH2)       | 32                 | RW     | 0000_0000h  |
| 110h      | Command Low Buffer Register (CMDL3)        | 32                 | RW     | 0000_0000h  |
| 114h      | Command High Buffer Register (CMDH3)       | 32                 | RW     | 0000_0000h  |
| 118h      | Command Low Buffer Register (CMDL4)        | 32                 | RW     | 0000_0000h  |
| 11Ch      | Command High Buffer Register (CMDH4)       | 32                 | RW     | 0000_0000h  |
| 120h      | Command Low Buffer Register (CMDL5)        | 32                 | RW     | 0000_0000h  |
| 124h      | Command High Buffer Register (CMDH5)       | 32                 | RW     | 0000_0000h  |
| 128h      | Command Low Buffer Register (CMDL6)        | 32                 | RW     | 0000_0000h  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset      | Register                                                    | Width<br>(In bits) | Access | Reset value |
|-------------|-------------------------------------------------------------|--------------------|--------|-------------|
| 12Ch        | Command High Buffer Register (CMDH6)                        | 32                 | RW     | 0000_0000h  |
| 130h        | Command Low Buffer Register (CMDL7)                         | 32                 | RW     | 0000_0000h  |
| 134h        | Command High Buffer Register (CMDH7)                        | 32                 | RW     | 0000_0000h  |
| 200h - 218h | Compare Value Register (CV1 - CV7)                          | 32                 | RW     | 0000_0000h  |
| 300h        | Data Result FIFO Register (RESFIFO0)                        | 32                 | R      | 0000_0000h  |
| 400h - 480h | Calibration General A-Side Registers (CAL_GAR0 - CAL_GAR32) | 32                 | RW     | 0000_0000h  |
| FF8h        | Configuration 2 Register (CFG2)                             | 32                 | RW     | 0000_1000h  |

#### 40.6.2 Version ID Register (VERID)

##### Offset

| Register | Offset |
|----------|--------|
| VERID    | 0h     |

##### Function

The Version ID register indicates the version integrated for this instance on the device and also indicates inclusion/exclusion of several optional features.

##### Diagram

|       |       |          |    |    |         |          |         |          |    |     |    |    |     |    |         |     |
|-------|-------|----------|----|----|---------|----------|---------|----------|----|-----|----|----|-----|----|---------|-----|
| Bits  | 31    | 30       | 29 | 28 | 27      | 26       | 25      | 24       | 23 | 22  | 21 | 20 | 19  | 18 | 17      | 16  |
| R     | MAJOR |          |    |    |         |          |         |          |    |     |    |    |     |    | MINOR   |     |
| W     |       |          |    |    |         |          |         |          |    |     |    |    |     |    |         |     |
| Reset | 0     | 0        | 0  | 0  | 0       | 0        | 1       | 0        | 0  | 0   | 0  | 0  | 0   | 0  | 0       | 0   |
| Bits  | 15    | 14       | 13 | 12 | 11      | 10       | 9       | 8        | 7  | 6   | 5  | 4  | 3   | 2  | 1       | 0   |
| R     | 0     | NUM_FIFO |    |    | NUM_SEC | CALO_FSI | IADCK_I | VR1R_NGI | 0  | CSW |    |    | MVI | 0  | DIFFE_N | RES |
| W     |       |          |    |    |         |          |         |          |    |     |    |    |     |    |         |     |
| Reset | 0     | 0        | 0  | 1  | 0       | 1        | 0       | 0        | 0  | 0   | 0  | 0  | 1   | 0  | 0       | 1   |

##### Fields

| Field | Function             |
|-------|----------------------|
| 31-24 | Major Version Number |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MAJOR             | This read-only field returns the major version number for the module specification.                                                                                                                                                                                                                                                                                                                                                                                                   |
| 23-16             | Minor Version Number                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| MINOR             | This read-only field returns the minor version number for the module specification.                                                                                                                                                                                                                                                                                                                                                                                                   |
| 15<br>—           | Reserved<br><br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                          |
| 14-12<br>NUM_FIFO | Number of FIFOs<br><br>This read-only field indicates the number of result FIFOs implemented in the design.<br><br>000b - N/A<br>001b - This design supports one result FIFO.<br>010b - This design supports two result FIFOs.<br>011b - This design supports three result FIFOs.<br>100b - This design supports four result FIFOs.                                                                                                                                                   |
| 11<br>NUM_SEC     | Number of Single Ended Outputs Supported<br><br>This read-only field indicates the number of single ended channels which can be processed simultaneously.<br><br>0b - This design supports one single ended conversion at a time.<br>1b - This design supports two simultaneous single ended conversions.                                                                                                                                                                             |
| 10<br>CALOFSI     | Calibration Function Implemented<br><br>This read-only field indicates if the ADC contains hardware calibration functions. When supported, CTRL[CALOFS] and CTRL[CAL_REQ] can be used to request the calibration routines to run.<br><br>0b - Calibration Not Implemented.<br>1b - Calibration Implemented.                                                                                                                                                                           |
| 9<br>IADCKI       | Internal ADC Clock Implemented<br><br>This read-only field indicates if this implementation of the ADC block includes an internal clock source. When supported, the CFG[ADCKEN] field is available and documented for enabling the clock source. When available, this clock source is used in clock selection logic external to the module for use within the system.<br><br>0b - Internal clock source not implemented.<br>1b - Internal clock source (and CFG[ADCKEN]) implemented. |
| 8<br>VR1RNGI      | Voltage Reference 1 Range Control Bit Implemented<br><br>This read-only field indicates if a control bit is implemented for selecting the input voltage range on Voltage Reference Option 1. When range control is required, the CFG[VREF1RNG] field is available and documented for controlling the Voltage Reference Option 1.                                                                                                                                                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | 0b - Range control not required. CFG[VREF1RNG] is not implemented.<br>1b - Range control required. CFG[VREF1RNG] is implemented.                                                                                                                                                                                                                                                                                                                                                |
| 7<br>—      | Reserved<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                        |
| 6-4<br>CSW  | Channel Scale Width<br>This read-only field indicates if channel scaling is supported by this implementation. When supported, each command buffer has a control field (CMDLa[CSCALE]) for setting input scaling.<br>000b - Channel scaling not supported.<br>001b - Channel scaling supported. 1-bit CSCALE control field.<br>110b - Channel scaling supported. 6-bit CSCALE control field.                                                                                     |
| 3<br>MVI    | Multi Vref Implemented<br>This read-only field indicates if multiple Voltage Reference High inputs are supported by this implementation. When multiple voltage references are supported, the CFG[REFSEL] field is available and documented for selecting the Voltage Reference High options.<br>0b - Single voltage reference high (VREFH) input supported.<br>1b - Multiple voltage reference high (VREFH) inputs supported.                                                   |
| 2<br>—      | Reserved<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1<br>DIFFEN | Differential Supported<br>This read-only field indicates if differential operation is supported by this implementation. When supported, CMDLa[CTYPE] in each command buffer is used for configuring for differential operation.<br>0b - Differential operation not supported.<br>1b - Differential operation supported.                                                                                                                                                         |
| 0<br>RES    | Resolution<br>This read-only field indicates the maximum accuracy supported by this implementation. When RES=1, each command buffer has a control field (CMDLa[MODE]) for selecting resolution of conversions for the associated command.<br>0b - Up to 12-bit single ended resolution supported (and 13-bit differential resolution if VERID[DIFFEN] = 1b).<br>1b - Up to 16-bit single ended resolution supported (and 16-bit differential resolution if VERID[DIFFEN] = 1b). |

### 40.6.3 Parameter Register (PARAM)

#### Offset

| Register | Offset |
|----------|--------|
| PARAM    | 4h     |

#### Function

The Parameter register indicates the size of several variable integration options for this instance on the device.

#### Diagram

| Bits  | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21       | 20 | 19 | 18 | 17 | 16 |
|-------|----------|----|----|----|----|----|----|----|----|----|----------|----|----|----|----|----|
| R     | CMD_NUM  |    |    |    |    |    |    |    |    |    | CV_NUM   |    |    |    |    |    |
| W     |          |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |
| Reset | 0        | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 0  | 0  | 0        | 0  | 0  | 1  | 1  | 1  |
| Bits  | 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5        | 4  | 3  | 2  | 1  | 0  |
| R     | FIFOSIZE |    |    |    |    |    |    |    |    |    | TRIG_NUM |    |    |    |    |    |
| W     |          |    |    |    |    |    |    |    |    |    |          |    |    |    |    |    |
| Reset | 0        | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0        | 0  | 0  | 1  | 0  | 0  |

#### Fields

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24<br>CMD_NUM | Command Buffer Number<br>Number of command buffers implemented.                                                                                                                                                                                                                                                                                                                                                                                                       |
| 23-16<br>CV_NUM  | Compare Value Number<br>Number of compare value registers implemented.                                                                                                                                                                                                                                                                                                                                                                                                |
| 15-8<br>FIFOSIZE | Result FIFO Depth<br>The maximum number of conversion datawords that can be stored in the result FIFO before an overflow occurs. This field is read-only.<br><br>0000_0001b - Result FIFO depth = 2 dataword.<br>0000_0100b - Result FIFO depth = 4 datawords.<br>0000_1000b - Result FIFO depth = 8 datawords.<br>0001_0000b - Result FIFO depth = 16 datawords.<br>0010_0000b - Result FIFO depth = 32 datawords.<br>0100_0000b - Result FIFO depth = 64 datawords. |
| 7-0<br>TRIG_NUM  | Trigger Number<br>Number of Triggers implemented.                                                                                                                                                                                                                                                                                                                                                                                                                     |

#### 40.6.4 Control Register (CTRL)

##### Offset

| Register | Offset |
|----------|--------|
| CTRL     | 10h    |

##### Function

Control Register includes primary control bits.

##### Diagram



##### Fields

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-25    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| —        | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 24-20    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| —        | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 19-16    | Auto-Calibration Averages                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| CAL_AVGS | <p>Selects how many ADC conversions are averaged to calculate each calibration value. Selecting a higher number of averages will lead to more accurate conversions after completing calibration. The recommended minimum setting is for 256 averaging (CAL_AVGS set to 0x8 or greater). The CAL_AVGS bit field applies to CALOFS, CAL_REQ and CALHS calibration functions. CAL_AVGS should be fixed when requesting and running calibration with CTRL[CAL_REQ], CTRL[CALOFS], or CTRL[CALHS].</p> <ul style="list-style-type: none"> <li>0000b - Single conversion.</li> <li>0001b - 2 conversions averaged.</li> <li>0010b - 4 conversions averaged.</li> <li>0011b - 8 conversions averaged.</li> </ul> |

Table continues on the next page...

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | 0100b - 16 conversions averaged.<br>0101b - 32 conversions averaged.<br>0110b - 64 conversions averaged.<br>0111b - 128 conversions averaged.<br>1000b - 256 conversions averaged.<br>1001b - 512 conversions averaged.<br>1010b - 1024 conversions averaged.                                                                                                                                                                                                                                                                                                                                                           |
| 15-9<br>—     | Reserved<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 8<br>RSTFIFO0 | Reset FIFO 0<br>0b - No effect.<br>1b - FIFO 0 is reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 7<br>—        | Reserved<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6<br>CALHS    | High Speed Mode Trim Request<br>Setting CALHS to 1 initiates a high speed mode trim calculation. Any conversions in progress are completed before launching the high speed mode calibration function. After being accepted, the ADC calculates the trim value and updates the HSTRIM register automatically. The CALHS bit is cleared by hardware upon completion of the high speed mode trim calculation. The STAT[CAL_RDY] bit indicates when the high speed mode calibration routine has completed.<br>0b - No request for high speed mode trim has been made<br>1b - Request for high speed mode trim has been made |
| 5<br>—        | Reserved<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 4<br>CALOFS   | Offset Calibration Request<br>Setting CALOFS to 1 initiates a hardware offset calibration calculation. Any conversions in progress are completed before launching the offset calibration function. After being accepted, the ADC calculates the offset value and updates either the OFSTRIM register automatically. The CALOFS bit is cleared by hardware upon completion of the offset calibration calculation. The STAT[CAL_RDY] bit indicates when the offset calibration routine has completed.<br>0b - No request for offset calibration has been made<br>1b - Request for offset calibration function             |
| 3<br>CAL_REQ  | Auto-Calibration Request                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | <p>Request the hardware calibration routine to run. This bit is automatically cleared when the system accepts the hardware calibration request. Note, the status flag STAT[CAL_RDY] will indicate when this calibration routine has been completed.</p> <p>0b - No request for hardware calibration has been made<br/>1b - A request for hardware calibration has been made</p>                                                                                                                                                                                                                                                                                                      |
| 2<br>DOZEN | <p>Doze Enable</p> <p>Controls system transition to low power modes while ADC is converting. When DOZEN is clear, immediate entries to low power modes are allowed. Note that the selected clock source provided from the on-chip clock source must be able to continue operating. When the DOZEN bit is set, the ADC waits for the current averaging iteration/FIFO storage to complete. When the system is entering a low power mode in which ADC operation is not supported, the DOZEN bit is ignored and the ADC waits for the current transfer to complete any pending operation.</p> <p>0b - ADC is enabled in low power mode.<br/>1b - ADC is disabled in low power mode.</p> |
| 1<br>RST   | <p>Software Reset</p> <p>Resets all internal logic and registers, except the Control Register. Remains set until cleared by software.</p> <p>0b - ADC logic is not reset.<br/>1b - ADC logic is reset.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0<br>ADCEN | <p>ADC Enable</p> <p>0b - ADC is disabled.<br/>1b - ADC is enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

#### 40.6.5 Status Register (STAT)

##### Offset

| Register | Offset |
|----------|--------|
| STAT     | 14h    |

##### Function

The Status Register provides the current status of the ADC module.

**Diagram**

| Bits  | 31 | 30 | 29 | 28 | 27         | 26      | 25          | 24       | 23 | 22 | 21 | 20 | 19     | 18   | 17 | 16 |
|-------|----|----|----|----|------------|---------|-------------|----------|----|----|----|----|--------|------|----|----|
| R     | 0  |    |    |    | CMDACT     |         |             |          | 0  |    |    |    | TRGACT |      |    |    |
| W     |    |    |    |    |            |         |             |          |    |    |    |    |        |      |    |    |
| Reset | 0  | 0  | 0  | 0  | 0          | 0       | 0           | 0        | 0  | 0  | 0  | 0  | 0      | 0    | 0  | 0  |
| Bits  | 15 | 14 | 13 | 12 | 11         | 10      | 9           | 8        | 7  | 6  | 5  | 4  | 3      | 2    | 1  | 0  |
| R     | 0  |    |    |    | ADC_ACT... | CAL_RDY | TCOM_P_I... | TEXC_INT | 0  |    |    |    | FOFO   | RDY0 |    |    |
| W     |    |    |    |    |            |         | W1C         | W1C      |    |    |    |    | W1C    |      |    |    |
| Reset | 0  | 0  | 0  | 0  | 0          | 0       | 0           | 0        | 0  | 0  | 0  | 0  | 0      | 0    | 0  | 0  |

**Fields**

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-27<br>—      | Reserved<br><br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 26-24<br>CMDACT | Command Active<br><br>CMDACT is a read-only status field indicating the command that is actively being processed. Note, commands are only shown here when they are actively being processed by the SAR routine. Use CMDACT in conjunction with ADC_ACTIVE to determine which conversion is running.<br><br>000b - No command is currently in progress.<br>001b - Command 1 currently being executed.<br>010b - Command 2 currently being executed.<br>011b-111b - Associated command number is currently being executed.                                                                                                                                             |
| 23-18<br>—      | Reserved<br><br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 17-16<br>TRGACT | Trigger Active<br><br>TRGACT is a read-only status field indicating the trigger actively being processed. This can be used to determine which trigger is running through a trigger delay or being converted by the SAR routine. The command associated with TRGACT will be running through a conversion when CMDACT is non-zero.<br><br>00b - Command (sequence) associated with Trigger 0 currently being executed.<br>01b - Command (sequence) associated with Trigger 1 currently being executed.<br>10b - Command (sequence) associated with Trigger 2 currently being executed.<br>11b - Command (sequence) associated with Trigger 3 currently being executed. |
| 15-12<br>—      | Reserved<br><br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 11              | ADC Active                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADC_ACTIVE     | <p>This flag shows if the module is currently processing a conversion, or has pending triggers to service. When the ADC is IDLE, this bit is set to 0b0.</p> <p>0b - The ADC is IDLE. There are no pending triggers to service and no active commands are being processed.</p> <p>1b - The ADC is processing a conversion, running through the power up delay, or servicing a trigger.</p>                                                                                                                                                                                       |
| 10<br>CAL_RDY  | <p>Calibration Ready</p> <p>This flag shows if the ADC CTRL[CAL_REQ] or CTRL[CALOFS] request for calibration has been completed and the results are ready. This flag is automatically cleared when a new hardware calibration or OFSTRIM request is made.</p> <p>0b - Calibration is incomplete or hasn't been ran.</p> <p>1b - The ADC is calibrated.</p>                                                                                                                                                                                                                       |
| 9<br>TCOMP_INT | <p>Interrupt Flag For Trigger Completion</p> <p>When a trigger sequence has been completed (all associated commands have been run) the TCOMP_INT flag is asserted. Note that IE[TCOMP_IE] must be set for the specific trigger source to flag an interrupt upon completion.</p> <p>0b - Either IE[TCOMP_IE] is set to 0, or no trigger sequences have run to completion.</p> <p>1b - Trigger sequence has been completed and all data is stored in the associated FIFO.</p>                                                                                                      |
| 8<br>TEXC_INT  | <p>Interrupt Flag For High Priority Trigger Exception</p> <p>When a high priority trigger exception has occurred and CFG[TRES] = 0, this flag is asserted. This flag only asserts if trigger exception interrupts are enabled (IE[TEXC_IE] = 0x1). This flag can be used in conjunction with TSTAT[TEXC_NUM] to resolve which trigger source was interrupted.</p> <p>0b - No trigger exceptions have occurred.</p> <p>1b - A trigger exception has occurred and is pending acknowledgement.</p>                                                                                  |
| 7-2<br>—       | <p>Reserved</p> <p>This read-only field is reserved and always has the value 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 1<br>FOF0      | <p>Result FIFO 0 Overflow Flag</p> <p>Indicates that more data has been written to the Result FIFO 0 than it can hold. The newer data is not stored and the FIFO remains holding the original contents. This flag asserts regardless of the value of IE[FOFIE0]. However, an interrupt request is issued only if IE[FOFIE0] is set. This flag is cleared by writing a 1.</p> <p>0b - No result FIFO 0 overflow has occurred since the last time the flag was cleared.</p> <p>1b - At least one result FIFO 0 overflow has occurred since the last time the flag was cleared.</p> |
| 0<br>RDY0      | <p>Result FIFO 0 Ready Flag</p> <p>Indicates when the number of valid datawords in the result FIFO 0 is greater than the watermark level set in the FCTRL[FWMARK] bitfield. This flag asserts regardless of the value of IE[FWMIE0]. However,</p>                                                                                                                                                                                                                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <p>an interrupt request or DMA request occurs only when the associated control bit (IE[FWMIE0] and DE[FWMDE0]) is set. This flag is cleared when the FCTRLa[FCOUNT] (which decrements on each read of the RESFIFO register) is less than or equal to the watermark level set in the FCTRL[FWMARK] bitfield.</p> <p>0b - Result FIFO 0 data level not above watermark level.<br/>1b - Result FIFO 0 holding data above watermark level.</p> |

#### 40.6.6 Interrupt Enable Register (IE)

##### Offset

| Register | Offset |
|----------|--------|
| IE       | 18h    |

##### Function

Interrupt Enable Register includes system interrupt masking control bits.

##### Diagram

|       |    |    |    |    |    |    |    |    |       |    |    |    |    |    |       |          |
|-------|----|----|----|----|----|----|----|----|-------|----|----|----|----|----|-------|----------|
| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19 | 18 | 17    | 16       |
| R     |    |    |    |    |    |    |    |    | 0     |    |    |    |    |    |       |          |
| W     |    |    |    |    |    |    |    |    |       |    |    |    |    |    |       | TCOMP_IE |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0  | 0  | 0  | 0  | 0  | 0     | 0        |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7     | 6  | 5  | 4  | 3  | 2  | 1     | 0        |
| R     |    |    |    |    | 0  |    |    |    | TEXC_ |    |    |    | 0  |    | FOFIE | FWMIE    |
| W     |    |    |    |    |    |    |    |    | IE    |    |    |    |    |    | 0     | E0       |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0     | 0  | 0  | 0  | 0  | 0  | 0     | 0        |

##### Fields

| Field             | Function                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-20<br>—        | <p>Reserved</p> <p>This read-only field is reserved and always has the value 0.</p>                                                                                                                                                                                                                                                                                                     |
| 19-16<br>TCOMP_IE | <p>Trigger Completion Interrupt Enable</p> <p>Each bit in TCOMP_IE corresponds to a trigger source. (TCOMP_IE[0] corresponds to trigger 0, TCOMP_IE[1] corresponds to trigger 1, ...) A trigger completion interrupt is used to indicate when a complete trigger command sequence has been executed. All results will be stored in the FIFO when a sequence is considered complete.</p> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                     |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | 0000b - Trigger completion interrupts are disabled.<br>0001b - Trigger completion interrupts are enabled for trigger source 0 only.<br>0010b - Trigger completion interrupts are enabled for trigger source 1 only.<br>0011b-1110b - Associated trigger completion interrupts are enabled.<br>1111b - Trigger completion interrupts are enabled for every trigger source.    |
| 15-9<br>—    | Reserved<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                     |
| 8<br>TEXC_IE | <b>Trigger Exception Interrupt Enable</b><br>This register field enables the ADC to assert an interrupt request when a high priority trigger exception occurs. TSTAT[TEXC_NUM] will contain the value of the corresponding trigger which was affected by the exception.<br>0b - Trigger exception interrupts are disabled.<br>1b - Trigger exception interrupts are enabled. |
| 7-2<br>—     | Reserved<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                     |
| 1<br>FOFIE0  | <b>Result FIFO 0 Overflow Interrupt Enable</b><br>Configures the module to generate overflow interrupt requests when FOF flag is asserted.<br>0b - FIFO 0 overflow interrupts are not enabled.<br>1b - FIFO 0 overflow interrupts are enabled.                                                                                                                               |
| 0<br>FWMIE0  | <b>FIFO 0 Watermark Interrupt Enable</b><br>Configures the module to generate watermark interrupt requests when STAT[RDY0] flag is asserted.<br>0b - FIFO 0 watermark interrupts are not enabled.<br>1b - FIFO 0 watermark interrupts are enabled.                                                                                                                           |

#### 40.6.7 DMA Enable Register (DE)

##### Offset

| Register | Offset |
|----------|--------|
| DE       | 1Ch    |

##### Function

DMA Enable Register includes DMA request masking control bits.

**Diagram**

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

**Fields**

| Field       | Function                                                                                                                                                                   |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-1<br>—   | Reserved<br>This read-only field is reserved and always has the value 0.                                                                                                   |
| 0<br>FWMDE0 | FIFO 0 Watermark DMA Enable<br>Configures the module to generate DMA requests when STAT[RDY0] flag is asserted.<br>0b - DMA request disabled.<br>1b - DMA request enabled. |

**40.6.8 Configuration Register (CFG)****Offset**

| Register | Offset |
|----------|--------|
| CFG      | 20h    |

**Function**

The Configuration Register controls ADC functions that are common to all commands. The CFG cannot be changed while the CTRL[ADCEN] bit is set. Writes to CFG while CTRL[ADCEN] is set are ignored.

**Diagram**

| Bits  | 31 | 30 | 29 | 28   | 27       | 26       | 25   | 24 | 23     | 22      | 21 | 20 | 19 | 18 | 17 | 16      |
|-------|----|----|----|------|----------|----------|------|----|--------|---------|----|----|----|----|----|---------|
| R     | 0  | 0  | 0  | PWRE | 0        |          |      |    |        |         |    |    |    |    |    |         |
| W     |    |    |    | N    |          |          |      |    |        |         |    |    |    |    |    |         |
| Reset | 0  | 0  | 0  | 0    | 0        | 0        | 0    | 0  | 1      | 0       | 0  | 0  | 0  | 0  | 0  | 0       |
| Bits  | 15 | 14 | 13 | 12   | 11       | 10       | 9    | 8  | 7      | 6       | 5  | 4  | 3  | 2  | 1  | 0       |
| R     | 0  |    |    | 0    | HPT_EXDI | TCMD RES | TRES |    | REFSEL | PWRS EL |    | 0  |    |    |    | TPRCTRL |
| W     |    |    |    |      |          |          |      |    |        |         |    |    |    |    |    |         |
| Reset | 0  | 0  | 0  | 0    | 0        | 0        | 0    | 0  | 0      | 0       | 0  | 0  | 0  | 0  | 0  | 0       |

**Fields**

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| —     | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 30    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| —     | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 29    | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| —     | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 28    | ADC Analog Pre-Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| PWREN | Enables the ADC analog circuits. When setting CFG[PWREN], user code should delay for a period exceeding the analog startup time of $t_{ADCSTUP}$ before enabling the ADC for operation. The module is still operational even when CFG[PWREN] is left clear but command execution start is delayed for a period defined by CFG[PUDLY]. Refer to the device datasheet for ADC idle and ADC active power consumption parameters.<br><br>0b - ADC analog circuits are only enabled while conversions are active. Performance is affected due to analog startup delays.<br><br>1b - ADC analog circuits are pre-enabled and ready to execute conversions without startup delays (at the cost of higher DC current consumption). Note that a single power up delay (CFG[PUDLY]) is executed immediately once PWREN is set, and any detected trigger does not begin ADC operation until the power up delay time has passed. After this initial delay expires the analog remains pre-enabled and no additional delays are executed. |
| 27-24 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| —     | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 23-16 | Power Up Delay                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| PUDLY | The PUDLY must be programmed to a non-zero value to enable the ADC. Note, the PUDLY is executed in one of two modes depending on the value configured in PWREN:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | <p>When CFG[PWREN]=0b0, the ADC analog circuits are only powered on while the module is active. The delay defined by CFG[PUDLY] is executed after an initial trigger transitions the ADC from its Idle state. This delay allows time for the analog circuits to stabilize after being powered on. The startup delay count of (PUDLY*4) ADCK cycles must result in a longer delay than the analog startup time of <math>t_{ADCSTUP}</math>. Accuracy of the initial conversion(s) after activation is degraded if CFG[PUDLY] is set to too small a value. At the end of active conversions, if there are no subsequent pending conversions, the ADC analog is automatically reverted back to its low power idle state and the PUDLY runs again after the ADC is awakened with a later trigger.</p> <p>When CFG[PWREN]=0b1 prior to ADC activation, the analog circuits are pre-enabled and the activation delay defined by CFG[PUDLY] is executed immediately. After the delay has been executed, the analog remains enabled regardless of ADC activity. This configuration has the benefit of beginning conversions immediately after trigger event detection at the cost of increased DC power consumption of the analog circuits. Note, the ADC does not begin an initial conversion until the PUDLY has been executed regardless of the PWREN setting.</p> |
| 15             | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| —              | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 14-11          | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| —              | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 10<br>HPT_EXDI | <p>High Priority Trigger Exception Disable</p> <p>Determines if high priority trigger exceptions are disabled. See section <a href="#">Trigger detect and command execution</a> for a detailed description on trigger exception handling. If HPT_EXDI = 1, then exceptions are disabled and fields CFG[TCMDRES], CFG[TRES], and CFG[TPRICTRL] are ignored.</p> <p>0b - High priority trigger exceptions are enabled.<br/>1b - High priority trigger exceptions are disabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 9<br>TCMDRES   | <p>Trigger Command Resume</p> <p>Determines where to resume from a high priority trigger exception. CFG[TRES] must be asserted for TCMDRES to be used. If asserted, the interrupted trigger sequence is resumed from the command where it was interrupted. If de-asserted the trigger sequence is restarted from the beginning.</p> <p>0b - Trigger sequences interrupted by a high priority trigger exception is automatically restarted.<br/>1b - Trigger sequences interrupted by a high priority trigger exception is resumed from the command executing before the exception.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 8<br>TRES      | <p>Trigger Resume Enable</p> <p>Determines what happens after completing a high priority trigger exception. If CFG[TRES] is asserted, the interrupted trigger sequence is resumed or restarted automatically. The sequence can be resumed along command boundaries or restarted from the beginning of a sequence. This is controlled by CFG[TCMDRES].</p> <p>If CFG[TRES] is de-asserted an interrupted trigger sequence does not resume automatically. In this case, interrupted triggers can be resumed via software by monitoring STAT[TEXC_INT] bit (or ISR handling for a trigger exception interrupt when IE[TEXC_IE] is set). Software determines which trigger was</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | <p>interrupted by reading TSTAT[TEXC_NUM] and re-starts the trigger with a write of 1 to the corresponding SWTRIG[SWTx] bit.</p> <p>0b - Trigger sequences interrupted by a high priority trigger exception are not automatically resumed or restarted.</p> <p>1b - Trigger sequences interrupted by a high priority trigger exception are automatically resumed or restarted.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 7-6<br>REFSEL   | <p>Voltage Reference Selection</p> <p>Selects the voltage reference high used for conversions.</p> <p><b>NOTE</b></p> <p>See the chip-specific ADC information on the voltage reference options specific to this packaged device.</p> <p>00b - (Default) Option 1 setting.</p> <p>01b - Option 2 setting.</p> <p>10b - Option 3 setting.</p> <p>11b - Reserved</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5<br>PWRSEL     | <p>Power Configuration Select</p> <p>Configures the module for power and performance. In the high-power setting, the highest conversion rates are possible. See the device data sheet for power and performance capabilities for each setting.</p> <p>0b - Low power</p> <p>1b - High power</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 4-2<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1-0<br>TPRICTRL | <p>ADC Trigger Priority Control</p> <p>Controls how higher priority trigger exceptions are handled. See <a href="#">Trigger detect and command execution</a> for a detailed explanation trigger event handling.</p> <p>00b - If a higher priority trigger is detected during command processing, the current conversion is aborted and the new command specified by the trigger is started.</p> <p>01b - If a higher priority trigger is received during command processing, the current command is stopped after completing the current conversion. If averaging is enabled, the averaging loop will be completed. However, CMDHa[LOOP] will be ignored and the higher priority trigger will be serviced.</p> <p>10b - If a higher priority trigger is received during command processing, the current command will be completed (averaging, looping, compare) before servicing the higher priority trigger.</p> <p>11b - Reserved</p> |

### 40.6.9 Pause Register (PAUSE)

#### Offset

| Register | Offset |
|----------|--------|
| PAUSE    | 24h    |

#### Function

The Pause Register controls an optional inserted delay between conversions. Note, the PAUSE register should not be modified while the CTRL[ADCEN] bit is set.

#### Diagram

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

#### Fields

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>PAUSEEN   | <p>PAUSE Option Enable</p> <p>Enables the ADC pausing function. When enabled, a programmable delay is inserted during command execution sequencing between LOOP iterations, between commands in a sequence, and between conversions when command is executing in for "Compare Until True" configuration. Note, CMDHa[WAIT_TRIG] and PAUSE are mutually exclusive. CMDHa[WAIT_TRIG] will take priority over PAUSE between commands when both are enabled.</p> <p>0b - Pause operation disabled<br/>1b - Pause operation enabled</p> |
| 30-9<br>—       | <p>Reserved</p> <p>This read-only field is reserved and always has the value 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 8-0<br>PAUSEDLY | <p>Pause Delay</p> <p>When PAUSEEN is set, the PAUSEDLY field controls the duration of pausing during command execution sequencing. The pause delay is a count of (PAUSEDLY*4) ADCK cycles.</p>                                                                                                                                                                                                                                                                                                                                    |

#### 40.6.10 Software Trigger Register (SWTRIG)

##### Offset

| Register | Offset |
|----------|--------|
| SWTRIG   | 34h    |

##### Function

The Software Trigger Register (SWTRIG) is written to initiate software triggered conversions. Writes to SWTRIG register are ignored while CTRL[ADCEN] is clear. Note that there is an approximately 3 ADC Clock cycle synchronization delay between asserting CTRL[ADCEN] until SWTRIG can be accepted.

##### Diagram

|       |    |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|------|------|------|------|
| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19   | 18   | 17   | 16   |
|       | R  |    |    |    |    |    |    |    | 0  |    |    |    |      |      |      |      |
|       | W  |    |    |    |    |    |    |    |    |    |    |    |      |      |      |      |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0    | 0    |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3    | 2    | 1    | 0    |
|       | R  |    |    |    | 0  |    |    |    |    |    |    |    | 0    | 0    | 0    | 0    |
|       | W  |    |    |    |    |    |    |    |    |    |    |    | SWT3 | SWT2 | SWT1 | SWT0 |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0    | 0    | 0    |

##### Fields

| Field     | Function                                                                                                                                                                                                                                          |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4<br>— | Reserved<br><br>This read-only field is reserved and always has the value 0.                                                                                                                                                                      |
| 3<br>SWT3 | Software Trigger 3 Event<br><br>Write 1 to SWT3 generates a trigger 3 event. Writing 1 to SWT3 is ignored while the trigger 3 event is being serviced or is pending.<br><br>0b - No trigger 3 event generated.<br>1b - Trigger 3 event generated. |
| 2<br>SWT2 | Software Trigger 2 Event<br><br>Write 1 to SWT2 generates a trigger 2 event. Writing 1 to SWT2 is ignored while the trigger 2 event is being serviced or is pending.<br><br>0b - No trigger 2 event generated.<br>1b - Trigger 2 event generated. |
| 1         | Software Trigger 1 Event                                                                                                                                                                                                                          |

Table continues on the next page...

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                                                                                  |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SWT1      | <p>Write 1 to SWT1 generates a trigger 1 event. Writing 1 to SWT1 is ignored while the trigger 1 event is being serviced or is pending.</p> <p>0b - No trigger 1 event generated.<br/>1b - Trigger 1 event generated.</p>                                 |
| 0<br>SWT0 | <p>Software Trigger 0 Event</p> <p>Write 1 to SWT0 generates a trigger 0 event. Writing 1 to SWT0 is ignored while the trigger 0 event is being serviced or is pending.</p> <p>0b - No trigger 0 event generated.<br/>1b - Trigger 0 event generated.</p> |

#### 40.6.11 Trigger Status Register (TSTAT)

##### Offset

| Register | Offset |
|----------|--------|
| TSTAT    | 38h    |

##### Function

This register contains status flags to indicate when trigger sequences have been completed or interrupted by a high priority trigger exception. Each bit in this register is set by hardware and cleared by software. To clear a bit in this register, write a 0b1 to the corresponding bit position.

##### Diagram

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

##### Fields

| Field | Function |
|-------|----------|
| 31-20 | Reserved |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field               | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —                   | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 19-16<br>TCOMP_FLAG | <p>Trigger Completion Flag</p> <p>Each bit corresponds to a trigger. When the corresponding trigger sequence has been completed a bit in TCOMP_FLAG will be set. For example, if trigger 3 has been completed, then bit 19 will be set in TSTAT. This register will only be active if the corresponding bit in IE[TCOMP_IE] = 1. Note, synchronization delay may be added to the end of the final conversion in a sequence prior to this flag being set. This delay can range from 2-4 ADC CLK cycles.</p> <ul style="list-style-type: none"> <li>0000b - No triggers have been completed. Trigger completion interrupts are disabled.</li> <li>0001b - Trigger 0 has been completed and trigger 0 has enabled completion interrupts.</li> <li>0010b - Trigger 1 has been completed and trigger 1 has enabled completion interrupts.</li> <li>0011b-1110b - Associated trigger sequence has completed and has enabled completion interrupts.</li> <li>1111b - Every trigger sequence has been completed and every trigger has enabled completion interrupts.</li> </ul> |
| 15-4<br>—           | <p>Reserved</p> <p>This read-only field is reserved and always has the value 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3-0<br>TEXC_NUM     | <p>Trigger Exception Number</p> <p>Each bit corresponds to a trigger. When the corresponding trigger sequence has been interrupted by a high priority trigger exception a 1 will be set in its bit position. For example, if trigger 3 has been interrupted, then bit 3 will be set in TSTAT. This register will be active regardless of the value in IE[TEXC_IE].</p> <ul style="list-style-type: none"> <li>0000b - No triggers have been interrupted by a high priority exception. Or CFG[TRES] = 1.</li> <li>0001b - Trigger 0 has been interrupted by a high priority exception.</li> <li>0010b - Trigger 1 has been interrupted by a high priority exception.</li> <li>0011b-1110b - Associated trigger sequence has interrupted by a high priority exception.</li> <li>1111b - Every trigger sequence has been interrupted by a high priority exception.</li> </ul>                                                                                                                                                                                              |

#### 40.6.12 Offset Trim Register (OFSTRIM)

##### Offset

| Register | Offset |
|----------|--------|
| OFSTRIM  | 40h    |

##### Function

The Offset Trim register is used to trim for comparator offset. The ADC supports an offset calibration function in which the OFSTRIM register is automatically updated.

To trigger the automatic update of OFSTRIM, set the CTRL[CALOFS] bit. Upon completion of the offset calibration sequence, the STAT[CAL\_RDY] bit is set to 0b1 and the OFSTRIM[OFSTRIM] bitfield is updated with a 10-bit signed value.

The OFSTRIM[OFSTRIM] value is used to minimize offset for normal conversions with a range of -512 to 511. For 16-bit conversions, each increment is 1/2 LSB resulting in a programmable offset range of -256 to +255.5 LSB. For 12-bit conversions, each increment is 1/32 LSB resulting in a programmable offset range of -16 to +15.96875 LSB.

The OFSTRIM[OFSTRIM] trim value is also used in the calibration function.

### Diagram

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

### Fields

| Field   | Function                                                                                                            |
|---------|---------------------------------------------------------------------------------------------------------------------|
| 31-10   | Reserved                                                                                                            |
| —       | This read-only field is reserved and always has the value 0.                                                        |
| 9-0     | Trim for Offset                                                                                                     |
| OFSTRIM | OFSTRIM is a 10-bit signed value between -512 and 511. This value is subtracted from the raw ADC conversion result. |

### 40.6.13 High Speed Trim Register (HSTRIM)

#### Offset

| Register | Offset |
|----------|--------|
| HSTRIM   | 48h    |

#### Function

The High Speed Trim register is used to trim for high speed function. The ADC supports an additional offset calibration function for high speed mode in which the HSTRIM register is automatically updated.

To trigger the automatic update of HSTRIM, set the CTRL[CALHS] bit. Upon completion of the high speed calibration sequence, the STAT[CAL\_RDY] bit is set to 0b1 and the HSTRIM[HSTRIM] bitfield is updated with a 5-bit signed value.

The HSTRIM[HSTRIM] value is used to minimize offset for high speed conversions (when CFG2[HS] is set). The HSTRIM register supports a range of -16 to 15.

**Diagram**

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

**Fields**

| Field         | Function                                                                                                                       |
|---------------|--------------------------------------------------------------------------------------------------------------------------------|
| 31-5<br>—     | Reserved<br>This read-only field is reserved and always has the value 0.                                                       |
| 4-0<br>HSTRIM | Trim for High Speed Conversions<br>HSTRIM is a 5-bit signed value between -16 and 15 that trims circuitry for high speed mode. |

**40.6.14 Trigger Control Register (TCTRL0 - TCTRL3)****Offset**

| Register | Offset |
|----------|--------|
| TCTRL0   | A0h    |
| TCTRL1   | A4h    |
| TCTRL2   | A8h    |
| TCTRL3   | ACh    |

**Function**

The Trigger Control (TCTRL $a$ ) register implements control fields associated with each implemented trigger source. When the ADC is actively executing commands, only one of the TCTRL $a$  registers is actively controlling ADC conversions. The actively controlling TCTRL $a$  register should not be updated while the ADC is active. A write to a TCTRL $a$  registers while that trigger control register is controlling the ADC operation may cause unpredictable behavior.

**Diagram**

| Bits  | 31         | 30 | 29 | 28 | 27   | 26   | 25 | 24 | 23        | 22 | 21 | 20 | 19 | 18   | 17 | 16 |  |
|-------|------------|----|----|----|------|------|----|----|-----------|----|----|----|----|------|----|----|--|
| R     | 0          |    |    |    | TCMD |      |    |    | TSYN<br>C | 0  |    |    |    | TDLY |    |    |  |
|       | W          |    |    |    |      |      |    |    |           |    |    |    |    |      |    |    |  |
| Reset | 0          | 0  | 0  | 0  | 0    | 0    | 0  | 0  | 0         | 0  | 0  | 0  | 0  | 0    | 0  | 0  |  |
| Bits  | 15         | 14 | 13 | 12 | 11   | 10   | 9  | 8  | 7         | 6  | 5  | 4  | 3  | 2    | 1  | 0  |  |
| R     | RSYNC<br>C | 0  |    |    |      | TPRI |    |    |           | 0  |    |    |    | HTEN |    |    |  |
|       |            | W  |    |    |      |      |    |    |           |    |    |    |    |      |    |    |  |
| Reset | 0          | 0  | 0  | 0  | 0    | 0    | 0  | 0  | 0         | 0  | 0  | 0  | 0  | 0    | 0  | 0  |  |

**Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-27<br>—    | Reserved<br><br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 26-24<br>TCMD | Trigger Command Select<br><br>Selects the command from command buffer to execute upon detection of the associated trigger event. When a trigger is received while the ADC is busy converting and the new trigger has higher priority than the trigger associated with the current command being executed, the command in this register, associated with the new trigger, is executed under control of CFG[TPRICTRL]. See section <a href="#">Trigger detect and command execution</a> for a more detailed description on the relationship between CFG[TPRICTRL] and TCMD.<br><br>000b - Not a valid selection from the command buffer. Trigger event is ignored.<br>001b - CMD1 is executed<br>010b-110b - Corresponding CMD is executed<br>111b - CMD7 is executed |
| 23<br>TSYNC   | Trigger Synchronous Select<br><br>Selects the ADC synchronous trigger input vs the asynchronous trigger                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 22-20<br>—    | Reserved<br><br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 19-16<br>TDLY | Trigger Delay Select<br><br>Selects the trigger delay duration to wait at the start of servicing a trigger event. Each trigger source has an associated programmable delay prior to beginning an initial conversion. When TDLY field is clear, then no delay is incurred. When TDLY is set to a non-zero value, the duration for the delay is $2^{TDLY}$ ADCK cycles.                                                                                                                                                                                                                                                                                                                                                                                               |
| 15<br>RSYNC   | Trigger Resync                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | <p>If RSYNC is set to 1, this trigger source will be used as a resync trigger. A resync trigger can be configured to restart or abort a running trigger sequence (the target). Each resync trigger is configured to have a resync target. When a resync trigger is asserted, the target sequence will be aborted, the target FIFO destination(s) will be cleared, and the target sequence can optionally be restarted depending on CFG[TRES]. Multiple conditions must be met for a resync trigger to execute properly.</p> <ol style="list-style-type: none"> <li>1. The resync trigger must have higher priority than the resync target.</li> <li>2. The resync trigger TCTRLa[RSYNC] must be set to 0b1.</li> <li>3. The resync target, specified by TCTRLa[TCMD], must be executing when the resync trigger is asserted.</li> </ol> <p>Please see <a href="#">Resync functionality</a> for more information.</p> |
| 14-10<br>—  | <p>Reserved</p> <p>This read-only field is reserved and always has the value 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 9-8<br>TPRI | <p>Trigger Priority Setting</p> <p>This bitfield sets the priority of the associated trigger source. If two or more triggers have the same priority level setting, the lower order trigger event has the higher priority (e.g., if Trigger 0 and Trigger 1 are both pending triggers and TCTRL0[TPRI] is configured the same as TCTRL1[TPRI], then the command associated with Trigger 0 is serviced first).</p> <ul style="list-style-type: none"> <li>00b - Set to highest priority, Level 1</li> <li>01b-10b - Set to corresponding priority level</li> <li>11b - Set to lowest priority, Level 4</li> </ul>                                                                                                                                                                                                                                                                                                      |
| 7-1<br>—    | <p>Reserved</p> <p>This read-only field is reserved and always has the value 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0<br>HTEN   | <p>Trigger Enable</p> <p>Enables hardware trigger source to initiate conversion on the rising-edge of the input trigger source.</p> <p><b>NOTE</b></p> <p>Enabling hardware trigger will not disable software triggers.</p> <ul style="list-style-type: none"> <li>0b - Hardware trigger source disabled</li> <li>1b - Hardware trigger source enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

#### 40.6.15 FIFO Control Register (FCTRL0)

##### Offset

| Register | Offset |
|----------|--------|
| FCTRL0   | E0h    |

## Function

The FIFO Control (FCTRLa) registers contain control and status fields for each FIFO in the design. A programmable watermark can be set for each FIFO which can be used to trigger an interrupt. In addition, the number of entries stored in each FIFO can be monitored by reading FCTRLa[FCOUNT].

## Diagram

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

## Fields

| Field  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-19  | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| —      | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                |
| 18-16  | Watermark Level Selection                                                                                                                                                                                                                                                                                                                                                                                                                   |
| FWMARK | FWMARK is a programmable threshold setting. When the number of datawords stored in the ADC Result FIFO is greater than the value in FWMARK, the STAT[RDY] flag is asserted to indicate stored data has reached the programmable threshold. When IE[FWMIE] is set, an interrupt request is generated. When DE[FWMDE] is set, a DMA request is generated.                                                                                     |
| 15-4   | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| —      | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                |
| 3-0    | Result FIFO Counter                                                                                                                                                                                                                                                                                                                                                                                                                         |
| FCOUNT | This read-only field indicates the number of datawords that are stored in the result FIFO. This value may be used in conjunction with PARAM[FIFOSIZE] to calculate how much room is left in the result FIFO. FCOUNT is incremented with each store of new data to the result FIFO and decrements with each read of the result FIFO. The FIFO is reset by writing to the CTRL[RSTFIFOx] bit, resulting in FCTRLa[FCOUNT] initialized to 0x0. |

## 40.6.16 Gain Calibration Control (GCC0)

### Offset

| Register | Offset |
|----------|--------|
| GCC0     | F0h    |

## Function

The Gain Calibration Control register (GCC0) hold intermediate values that are utilized as part of the calibration steps. The GCCa[GAIN\_CAL] field is calculated with hardware and auto updated during the calibration steps. Once the hardware calibration sequence has updated GCCa[GAIN\_CAL] the GCCa[RDY] status flag is asserted automatically. Note that requesting a calibration routine automatically clears the GCCa[RDY] bit until the new GCCa[GAIN\_CAL] value is calculated. For the calibration steps to be completed, further software processing is needed where the GCCa[GAIN\_CAL] value is used to calculate the gain adjustment and the result is stored to GCRa[GCALR]. For more information see [Calibration](#) in the functional description.

## Diagram

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

## Fields

| Field    | Function                                                                                                                                                                                                                                                                                                                     |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-25    | Reserved                                                                                                                                                                                                                                                                                                                     |
| —        | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                 |
| 24       | Gain Calibration Value Valid                                                                                                                                                                                                                                                                                                 |
| RDY      | This status flag indicates when the data stored in GCCa[GAIN_CAL] is valid.<br><br>0b - The GAIN_CAL value is invalid. Run the hardware calibration routine for this value to be set.<br><br>1b - The GAIN_CAL value is valid. GAIN_CAL should be used by software to derive GCRa[GCALR].                                    |
| 23-16    | Reserved                                                                                                                                                                                                                                                                                                                     |
| —        | This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                 |
| 15-0     | Gain Calibration Value                                                                                                                                                                                                                                                                                                       |
| GAIN_CAL | GAIN_CAL is read-only. As part of the hardware calibration steps, GAIN_CAL is automatically updated with a 16-bit signed number and is used in the gain adjustment calculations to derive the value written to the GCRa[GCALR] register. For more information see <a href="#">Calibration</a> in the functional description. |

#### 40.6.17 Gain Calculation Result (GCR0)

##### Offset

| Register | Offset |
|----------|--------|
| GCR0     | F8h    |

##### Function

The Gain Calculation Result register (GCR0) is used during ADC conversions for automated gain error adjustment. Determining the values to store to GCC0[GCALR] is the result of software calculations described in setup steps in [Calibration](#). There is a RDY status flag in the GCR register which indicates whether the value GCRA[GCALR] is valid. Upon writing the GCRA[GCALR] value, the user should also assert GCRA[RDY] to indicate that the gain adjustment result is valid.

After beginning a calibration sequence by asserting CTRL[CAL\_REQ], the calibration sequence is not complete until GCRA[GCALR] is calculated and GCRA[RDY] is asserted. The gain adjustment calculation results in a floating point value between 0 and 2. GCRA[GCALR][16] holds the integer value (0 or 1) and GCRA[GCALR][15:0] holds the 16-bit fractional component of the gain adjustment calculation. To convert the GCRA[GCALR] value back into the gain adjustment value in decimal format, this would be calculated as:  $1 \cdot \text{GCRA}[16] + 0.5 \cdot \text{GCRA}[15] + 0.25 \cdot \text{GCRA}[14] + 0.125 \cdot \text{GCRA}[13] + \dots$

##### Diagram



##### Fields

| Field      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-25<br>— | Reserved<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 24<br>RDY  | Gain Calculation Ready<br>The RDY flag indicates to the ADC when the data stored in GCRA[GCALR] is valid and is used for gain adjustment. The GCRA[GCALR] must be written from memory or calculated each time the calibration routine is run. The RDY flag must be asserted by the user after writing valid data into the GCALR field. The RDY flag is cleared automatically when requesting a new calibration sequence.<br>0b - The GCALR value is invalid.<br>1b - The GCALR value is valid. |

Table continues on the next page...

*Table continued from the previous page...*

| Field         | Function                                                                                                                                  |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 23-17<br>—    | Reserved<br>This read-only field is reserved and always has the value 0.                                                                  |
| 16-0<br>GCALR | Gain Calculation Result<br>This value holds the 17-bit value generated from the gain adjustment calculation during the calibration steps. |

#### 40.6.18 Command Low Buffer Register (CMDL1 - CMDL7)

##### Offset

| Register | Offset |
|----------|--------|
| CMDL1    | 100h   |
| CMDL2    | 108h   |
| CMDL3    | 110h   |
| CMDL4    | 118h   |
| CMDL5    | 120h   |
| CMDL6    | 128h   |
| CMDL7    | 130h   |

##### Function

There are 7 command buffers (CMD $a$ ), each constructed from two 32-bit registers (CMDL $a$ :CMDH $a$ ) that can be configured for different channel select and varying conversion options. Any of the command buffers is selected and used as the controlling command by association to a trigger event via configuration of the TCTRLA $a$ [TCMD] bitfield. When the ADC is actively executing commands, only one of the CMD buffers is actively controlling ADC conversions. The actively controlling CMD buffer should not be updated while the ADC is active. A write to a CMD buffer while that CMD buffer is controlling the ADC operation may cause unpredictable behavior.

##### NOTE

The 7 command buffers are numbered [CMDH1:CMDL1] through [CMDH7:CMDL7]. In NXP-supplied header files, these are likely to be defined as two 7-element arrays that are indexed from 0. I.e., the type declaration would be:

```
unsigned int CMDL[7];  
unsigned int CMDH[7];
```

and software would access ADC0 CMDH1 as `ADC0 ->CMDH[0]` and ADC0 CMDL7 as `ADC0 ->CMDL[6]`.

The CMDL $a$ [ADCH] and CMDL $a$ [CTYPE] bitfields control selection of input channels. Each ADC command independently makes a channel selection.

**NOTE**

Some of the input channels are from on-chip sources such as temperature sensors and reference voltage sources and may only be connected to individual instances of the ADC module. Some of the input channel options in the bitfield-setting descriptions may not be available for your device. Refer to chip-specific information for the channels supported on this device.

**Diagram**

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

**Fields**

| Field        | Function                                                                                                                                                                                                      |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24        | Reserved                                                                                                                                                                                                      |
| —            | This read-only field is reserved and always has the value 0.                                                                                                                                                  |
| 23-16        | Reserved                                                                                                                                                                                                      |
| —            | This read-only field is reserved and always has the value 0.                                                                                                                                                  |
| 15-14        | Reserved                                                                                                                                                                                                      |
| —            | This read-only field is reserved and always has the value 0.                                                                                                                                                  |
| 13-8         | Reserved                                                                                                                                                                                                      |
| —            | This read-only field is reserved and always has the value 0.                                                                                                                                                  |
| 7<br>MODE    | Select Resolution of Conversions<br><br>The MODE field, selects the ADC resolution.<br><br>0b - Standard resolution. Single-ended 12-bit conversion.<br>1b - High resolution. Single-ended 16-bit conversion. |
| 6-5<br>CTYPE | Conversion Type<br><br>Zero is the only valid program value and selects A-side channels for conversion.<br><br>00b - Single-Ended Mode. Only A side channel is converted.<br>01b-11b - Reserved.              |
| 4-0          | Input Channel Select                                                                                                                                                                                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADCH  | <p style="text-align: center;"><b>NOTE</b></p> <p>Some of the input channels are from internal resources such as temperature sensors and bandgap voltage sources and may only be connected to individual instances of the ADC module. Some of the input channel options in the bitfield-setting descriptions might not be available for your device. For the ADC channel assignments for your device, see the chip-specific information.</p> <p>0_0000b - Select CH0A.<br/>     0_0001b - Select CH1A.<br/>     0_0010b - Select CH2A.<br/>     0_0011b - Select CH3A.<br/>     0_0100b-1_1101b - Select corresponding channel CHnA.<br/>     1_1110b - Select CH30A.<br/>     1_1111b - Select CH31A.</p> |

#### 40.6.19 Command High Buffer Register (CMDH1 - CMDH7)

##### Offset

| Register | Offset |
|----------|--------|
| CMDH1    | 104h   |
| CMDH2    | 10Ch   |
| CMDH3    | 114h   |
| CMDH4    | 11Ch   |
| CMDH5    | 124h   |
| CMDH6    | 12Ch   |
| CMDH7    | 134h   |

##### Function

There are 7 command buffers (CMD $a$ ), each constructed from two 32-bit registers (CMDL $a$ :CMDH $a$ ) that can be configured for different channel select and varying conversion options. Any of the command buffers is selected and used as the controlling command by association to a trigger event via configuration of the TCTRL $a$ [TCMD] bitfield. When the ADC is actively executing commands, only one of the CMD buffers is actively controlling ADC conversions. The actively controlling CMD buffer should not be updated while the ADC is active. A write to a CMD buffer while that CMD buffer that is controlling ADC operation may result in unpredictable behavior.

**NOTE**

The 7 command buffers are numbered [CMDH1:CMDL1] through [CMDH7:CMDL7]. In NXP-supplied header files, these are likely to be defined as two 7-element arrays that are indexed from 0. I.e., the type declaration would be:

```
unsigned int CMDL[7];  
unsigned int CMDH[7];
```

and software would access ADC0 CMDH1 as `ADC0 ->CMDH[0]` and ADC0 CMDL7 as `ADC0 ->CMDL[6]`.

**Diagram****Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-27<br>—    | Reserved<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 26-24<br>NEXT | Next Command Select<br>Selects the next command to be executed after this command completes. Multiple commands can be configured in a scan configuration by linking the next command in a daisy-chain sequence. The command buffer number is not indicative of any particular order and the order of execution is strictly controlled by the NEXT field (for example, a sequence of commands could be CMD2 to CMD1 to CMD3). Unending circular command execution is allowed by setting the NEXT field in the last command in a sequence to the first command in the sequence. It is also allowed for a command to set the next command to itself, resulting in a continuous conversion configuration. Setting the next command to 0x0 causes conversions to terminate at the completion of the command. Lower priority trigger events cannot be serviced until a higher priority triggered command (or sequence of commands) completes.<br><br>000b - No next command defined. Terminate conversions at completion of current command. If lower priority trigger pending, begin command associated with lower priority trigger.<br>001b - Select CMD1 command buffer register as next command.<br>010b-110b - Select corresponding CMD command buffer register as next command<br>111b - Select CMD7 command buffer register as next command. |
| 23-20<br>—    | Reserved<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19-16<br>LOOP | <p>Loop Count Select</p> <p>Selects how many times this command executes (and stores conversion result to RESFIFO) before finish and transition to the next command or Idle state. LWI field controls whether a single channel is converted on each iteration or auto channel increment results in channel scanning functionality.</p> <ul style="list-style-type: none"> <li>0000b - Looping not enabled. Command executes 1 time.</li> <li>0001b - Loop 1 time. Command executes 2 times.</li> <li>0010b - Loop 2 times. Command executes 3 times.</li> <li>0011b-1110b - Loop corresponding number of times. Command executes LOOP+1 times.</li> <li>1111b - Loop 15 times. Command executes 16 times.</li> </ul>                                                                                                                                                                                                                                                                                               |
| 15-12<br>AVGS | <p>Hardware Average Select</p> <p>Selects how many ADC conversions are averaged to create the ADC result (<math>2^{AVGS}</math>). An internal storage buffer is used to capture temporary results while the averaging iterations are executed. Hardware averaging is a nested loop control and does not extend across LOOP boundaries. See <a href="#">Functional description</a> for more detailed description on usage of AVGS, LOOP, and NEXT bitfields in command execution sequencing.</p> <ul style="list-style-type: none"> <li>0000b - Single conversion.</li> <li>0001b - 2 conversions averaged.</li> <li>0010b - 4 conversions averaged.</li> <li>0011b - 8 conversions averaged.</li> <li>0100b - 16 conversions averaged.</li> <li>0101b - 32 conversions averaged.</li> <li>0110b - 64 conversions averaged.</li> <li>0111b - 128 conversions averaged.</li> <li>1000b - 256 conversions averaged.</li> <li>1001b - 512 conversions averaged.</li> <li>1010b - 1024 conversions averaged.</li> </ul> |
| 11<br>—       | <p>Reserved</p> <p>This read-only field is reserved and always has the value 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 10-8<br>STS   | <p>Sample Time Select</p> <p>When programmed to 0b000 the minimum sample time of 3.5 ADCK cycles is selected. When STS is programmed to a non-zero value the sample time is <math>(3.5 + 2^{STS})</math> ADCK cycles. The shortest sample time maximizes conversion speed for lower impedance inputs. Extending sample time allows higher impedance inputs to be accurately sampled. Longer sample times can also be used to lower overall power consumption when command looping and sequencing is configured and high conversion rates are not required.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | <p>000b - Minimum sample time of 3.5 ADCK cycles.</p> <p>001b - 3.5 + <math>2^1</math> ADCK cycles; 5.5 ADCK cycles total sample time.</p> <p>010b - 3.5 + <math>2^2</math> ADCK cycles; 7.5 ADCK cycles total sample time.</p> <p>011b - 3.5 + <math>2^3</math> ADCK cycles; 11.5 ADCK cycles total sample time.</p> <p>100b - 3.5 + <math>2^4</math> ADCK cycles; 19.5 ADCK cycles total sample time.</p> <p>101b - 3.5 + <math>2^5</math> ADCK cycles; 35.5 ADCK cycles total sample time.</p> <p>110b - 3.5 + <math>2^6</math> ADCK cycles; 67.5 ADCK cycles total sample time.</p> <p>111b - 3.5 + <math>2^7</math> ADCK cycles; 131.5 ADCK cycles total sample time.</p>                                                                                                    |
| 7<br>LWI       | <p>Loop with Increment</p> <p>Enables automatic channel incrementing. When 0, the LOOP field selects the number of times the selected channel is converted consecutively. When 1, automatic channel incrementing is enabled and the LOOP field defines how many consecutive channels are converted as part of the command execution.</p> <p>Example 1: LOOP = 8h, LWI = 0b, CMDLn[CTYPE] = 0h, CMDLn[ADCH] = Dh. Convert on channel 13A 9 times.</p> <p>Example 2: LOOP = 8h, LWI = 1b, CMDLn[CTYPE] = 0h, CMDLn[ADCH] = Dh. Run channels 13A-21A each one time.</p> <p>Maximum channel scanning using a single command buffer is defined by the maximum value of the LOOP field (16).</p> <p>0b - Auto channel increment disabled</p> <p>1b - Auto channel increment enabled</p> |
| 6-3<br>—       | <p>Reserved</p> <p>This read-only field is reserved and always has the value 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 2<br>WAIT_TRIG | <p>Wait for Trigger Assertion before Execution.</p> <p>Controls if commands are automatically executed or if a trigger must be received before execution. If WAIT_TRIG is asserted, wait states will be added before the command until the active trigger is asserted again. When WAIT_TRIG is disabled, each command will be automatically executed when called.</p> <p>0b - This command will be automatically executed.</p> <p>1b - The active trigger must be asserted again before executing this command.</p>                                                                                                                                                                                                                                                               |
| 1-0<br>CMPEN   | <p>Compare Function Enable</p> <p>After an ADC channel input is sampled and converted and any averaging iterations are performed, the CMDH<sub>n</sub>[CMPEN] field guides operation of the automatic compare function to optionally only store when the compare operation is true. When compare is enabled, the conversion result is compared to the compare value registers (CV<sub>a</sub>[CVH] and CV<sub>a</sub>[CVL]). There are multiple options on command sequencing related to the compare function. See <a href="#">Compare function</a> for a detailed explanation of the compare options.</p>                                                                                                                                                                        |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | <p style="text-align: center;"><b>NOTE</b></p> <p>Not all Command Buffers have implemented the CMPEN field. The CMPEN field is only available in Command Buffers that have a corresponding Compare Value register.</p> <p>00b - Compare disabled.<br/>01b - Reserved<br/>10b - Compare enabled. Store on true.<br/>11b - Compare enabled. Repeat channel acquisition (sample/convert/compare) until true.</p> |

#### 40.6.20 Compare Value Register (CV1 - CV7)

##### Offset

| Register | Offset |
|----------|--------|
| CV1      | 200h   |
| CV2      | 204h   |
| CV3      | 208h   |
| CV4      | 20Ch   |
| CV5      | 210h   |
| CV6      | 214h   |
| CV7      | 218h   |

##### Function

The compare value registers (CV $a$ ) contain values used to compare the conversion result when the compare function is enabled. This register is formatted in the same way as the D field in the RESFIFO registers in different modes of operation for both bit position definition and value format using unsigned or signed 2's complement. There is a direct association of each compare value register to a specific command buffer register (i.e., CV1 is only used during execution of CMD1 command).

**NOTE**

Not all Command Buffers have an associated Compare Value register. The compare function is only available on Command Buffers that have a corresponding Compare Value register.

When the ADC is actively executing commands, the CV $a$  register associated with the active command (CMD $a$ ) should not be updated. Writes to associated CV $a$  register during this time may result in unpredictable behavior.

**NOTE**

The 7 compare value registers are numbered [CV1] through [CV7]. In NXP-supplied header files, this is likely to be defined as a 7-element array that is indexed from 0. I.e., the type declaration would be:

```
unsigned int CV[7];
```

and software would access ADC0 CV1 as ADC0->CV[0] and ADC0 CV7 as ADC0->CV[6].

**Diagram**

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

**Fields**

| Field        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16<br>CVH | Compare Value High<br><br>The compare function can be configured to check whether the result is less than, greater than, or if the result falls within or outside a range determined by two compare values. After the input is sampled and converted and any averaging iterations are performed, the compare values in CVL and CVH are optionally used in a compare operation on the result. See <a href="#">Compare function</a> for a description on how CVH is used. |
| 15-0<br>CVL  | Compare Value Low<br><br>The compare function can be configured to check whether the result is less than, greater than, or if the result falls within or outside a range determined by two compare values. After the input is sampled and converted and any averaging iterations are performed, the compare values in CVL and CVH are optionally used in a compare operation on the result. See <a href="#">Compare function</a> for a description on how CVL is used.  |

**40.6.21 Data Result FIFO Register (RESFIFO0)****Offset**

| Register | Offset |
|----------|--------|
| RESFIFO0 | 300h   |

**Function**

The data result FIFO register (RESFIFO) is a 8 entry FIFO that stores the data result of ADC conversions. In addition, several tag fields of source command and trigger information are stored along with the data. FCTRLa[FCOUNT] indicates how many valid datawords are stored in the RESFIFO. Reading RESFIFO provides the oldest unread dataword entry in the FIFO and decrements FCTRLa[FCOUNT]. The FIFO can be emptied by successive reads of RESFIFO. The FIFO is reset by writing 0b1 to the CTRL[RSTFIFOx] bit.

The following table describes the format of data in the result FIFO.

Table 250. Data result register format description

| Conversion mode     | D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Format                                      |
|---------------------|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|---------------------------------------------|
| 16-bit single-ended | D   | D   | D   | D   | D   | D   | D  | D  | D  | D  | D  | D  | D  | D  | D  | D  | Unsigned, 16-bit magnitude, JLEFT=X         |
| 12-bit single-ended | 0   | D   | D   | D   | D   | D   | D  | D  | D  | D  | D  | D  | 0  | 0  | 0  | 0  | Unsigned, JLEFT=0, zero in D[15] and D[2:0] |
| 12-bit single-ended | D   | D   | D   | D   | D   | D   | D  | D  | D  | D  | D  | 0  | 0  | 0  | 0  | 0  | Unsigned, JLEFT=1, zero in D[3:0]           |

**NOTE**

D: Data

## Diagram

| Bits  | 31    | 30 | 29 | 28 | 27     | 26 | 25 | 24      | 23 | 22 | 21 | 20 | 19 | 18 | 17   | 16 |
|-------|-------|----|----|----|--------|----|----|---------|----|----|----|----|----|----|------|----|
| R     | VALID |    | 0  |    | CMDSRC |    |    | LOOPCNT |    |    |    |    | 0  |    | TSRC |    |
| W     |       |    |    |    |        |    |    |         |    |    |    |    |    |    |      |    |
| Reset | 0     | 0  | 0  | 0  | 0      | 0  | 0  | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0  |
| Bits  | 15    | 14 | 13 | 12 | 11     | 10 | 9  | 8       | 7  | 6  | 5  | 4  | 3  | 2  | 1    | 0  |
| R     |       |    |    |    |        |    |    |         | D  |    |    |    |    |    |      |    |
| W     |       |    |    |    |        |    |    |         |    |    |    |    |    |    |      |    |
| Reset | 0     | 0  | 0  | 0  | 0      | 0  | 0  | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0  |

## Fields

| Field           | Function                                                                                                                                                                                                                                                                                         |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>VALID     | FIFO Entry is Valid<br><br>Indicate the FIFO entry is valid. When the FIFO is holding data the VALID bit is set. When the FIFO is empty the VALID bit is clear.<br><br>0b - FIFO is empty. Discard any read from RESFIFO.<br>1b - FIFO record read from RESFIFO is valid.                        |
| 30-27<br>—      | Reserved<br><br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                     |
| 26-24<br>CMDSRC | Command Buffer Source<br><br>Indicate the command buffer being executed that generated this result.<br><br>000b - Not a valid value CMDSRC value for a dataword in RESFIFO. 0x0 is only found in initial FIFO state prior to an ADC conversion result dataword being stored to a RESFIFO buffer. |

Table continues on the next page...

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | 001b - CMD1 buffer used as control settings for this conversion.<br>010b-110b - Corresponding command buffer used as control settings for this conversion.<br>111b - CMD7 buffer used as control settings for this conversion.                                                                                                                                                                                                                                                                                                                                                                               |
| 23-20<br>LOOPCNT | Loop Count Value<br>Indicate the loop count value during command execution that generated this result. When CMDHa[LOOP] is non-zero, the command execution stores off a result multiple times during command execution (at the loop boundary). <ul style="list-style-type: none"> <li>0000b - Result is from initial conversion in command.</li> <li>0001b - Result is from second conversion in command.</li> <li>0010b-1110b - Result is from LOOPCNT+1 conversion in command.</li> <li>1111b - Result is from 16<sup>th</sup> conversion in command.</li> </ul>                                           |
| 19-18<br>—       | Reserved<br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 17-16<br>TSRC    | Trigger Source<br>Indicate the trigger source that initiated a conversion and generated this result. When multiple commands are chained together using the CMDHa[NEXT] field, the TSRC field for all datawords stored to the RESFIFO indicate the trigger source that started the sequence of commands. <ul style="list-style-type: none"> <li>00b - Trigger source 0 initiated this conversion.</li> <li>01b - Trigger source 1 initiated this conversion.</li> <li>10b-10b - Corresponding trigger source initiated this conversion.</li> <li>11b - Trigger source 3 initiated this conversion.</li> </ul> |
| 15-0<br>D        | Data Result<br>The formatting for the data in D is summarized in <a href="#">Table 250</a> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

#### 40.6.22 Calibration General A-Side Registers (CAL\_GAR0 - CAL\_GAR32)

##### Offset

For a = 0 to 32:

| Register | Offset          |
|----------|-----------------|
| CAL_GARa | 400h + (a × 4h) |

##### Function

The A-side general calibration value registers (CAL\_GAR0 - CAL\_GAR32) are used to correct for linearity errors of the A-side converter. All 33 CAL\_GAR registers contain calibration information that is automatically updated during the self calibration sequence. See [Calibration](#) for more information on completing ADC calibration steps.

The calibration values in the CAL\_GAR registers affect the end conversion result by conditionally being subtracted from the conversion before the end result is transferred into the FIFOs. Calibration must be run each time the ADC is powered down or a hard reset is issued. To reduce the latency required to run calibration, the CAL\_GAR values can be stored in non-volatile memory after an initial calibration and recovered prior to the first ADC conversion. If these registers are set to values not generated by the calibration function, the linearity error specifications may not be met.

The CAL\_GAR registers are only read write accessible when the ADC is disabled with CTRL[ADCEN] = 0b0. Note that access time when writing to these registers is larger than 3 ADC clock cycles. Wait states are inserted on the bus to meet synchronization timing to the associated CAL\_GAR register.

Note that the values in each register is a 16-bit signed value but has non-uniform supported range of values. The valid range of each register is summarized in [Calibration General A-Side Register valid ranges](#).

### Diagram

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

### Fields

| Field       | Function                                                                                                                                                                                      |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-16       | Reserved                                                                                                                                                                                      |
| —           | This read-only field is reserved and always has the value 0.                                                                                                                                  |
| 15-0        | Calibration General A Side Register Element                                                                                                                                                   |
| CAL_GAR_VAL | The CAL_GAR_VAL is a 16-bit signed value. The valid range for each register in this array is non-uniform and summarized in <a href="#">Calibration General A-Side Register valid ranges</a> . |

### 40.6.23 Configuration 2 Register (CFG2)

#### Offset

| Register | Offset |
|----------|--------|
| CFG2     | FF8h   |

#### Function

The Configuration 2 Register controls ADC functions that are common to all commands. The CFG2 cannot be changed while the CTRL[ADCEN] bit is set. Writes to CFG2 while CTRL[ADCEN] is set are ignored.

**Diagram**

| Bits  | 31 | 30   | 29 | 28 | 27          | 26 | 25    | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|------|----|----|-------------|----|-------|----|----|----|----|----|----|----|----|----|
| R     | 0  |      |    |    |             |    |       |    |    |    |    |    |    |    |    |    |
| W     |    |      |    |    |             |    |       |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0    | 0  | 0  | 0           | 0  | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bits  | 15 | 14   | 13 | 12 | 11          | 10 | 9     | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     | 0  | TUNE |    | 0  | HSEX<br>TRA | HS | JLEFT | 0  |    |    |    |    |    |    |    |    |
| W     |    |      |    |    | 0           | 0  | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Reset | 0  | 0    | 0  | 1  | 0           | 0  | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Fields**

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-14<br>—    | Reserved<br><br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                        |
| 13-12<br>TUNE | Tune Mode register<br><br>TUNE provides some variability in how many cycles are needed to complete a conversion. Conversions can be terminated early at the expense of conversion resolution. See <a href="#">Cycles per conversion</a> for more information on TUNE affect on conversion duration.                                                                                                                                                                                 |
| 11<br>—       | Reserved<br><br>This read-only field is reserved and always has the value 0.                                                                                                                                                                                                                                                                                                                                                                                                        |
| 10<br>HSEXTA  | High Speed Extra register<br><br>In high speed conversions (when CFG2[HS] bit set to 1), HSEXTA provides a secondary control to add an additional ADCK cycle to the conversion. Setting to 1 is needed in a specific corner of operation where VDDA < TBD V and ADCK > TBD Hz. See <a href="#">Cycles per conversion</a> for more information on HSEXTA affect on conversion duration.<br><br>0b - No extra cycle added<br>1b - Extra cycle added                                   |
| 9<br>HS       | High Speed Enable register<br><br>Configures ADC for high speed conversions at the expense of higher operating current. When HS is set, conversions complete 2 or 3 ADCK cycles sooner (depending on the CFG2[HSEXTA] setting) compared to conversion cycle counts when HS is clear. See <a href="#">Cycles per conversion</a> for more information on HS affect on conversion duration.<br><br>0b - High speed conversion mode disabled<br>1b - High speed conversion mode enabled |
| 8<br>JLEFT    | Justified Left Enable register                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                                                                                                                                                                                                                             |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | <p>When JLEFT is set and the ADC is converting in 12-bit single-ended mode, conversion result stores to RESFIFO<sub>n</sub>[D] are in left-justify format. The formatting for the data in RESFIFO<sub>n</sub>[D] is summarized in <a href="#">Table 250</a>.</p> <p><b>NOTE</b></p> <p>In JLEFT mode, CVL and CVH must be programmed in left-justify format to generate correct compare results.</p> |
| 7-0<br>— | <p>Reserved</p> <p>— This read-only field is reserved and always has the value 0.</p>                                                                                                                                                                                                                                                                                                                |

# Chapter 41

## Low-Power Comparator (CMP)

### 41.1 Chip-specific CMP information

Table 251. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | CMP            | <a href="#">CMP</a>                 |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power management    |                | <a href="#">Power management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 41.1.1 Module instances

This device has two instances of the CMP module, CMP0, and CMP1.

#### 41.1.2 Input connections

Table 252. Input connections

| Index | CMP0_Positive | CMP0_Negative | CMP1_Positive | CMP1_Negative | Description |
|-------|---------------|---------------|---------------|---------------|-------------|
| 0     | CMP0_IN0      | CMP0_IN0      | CMP1_IN0      | CMP1_IN0      | VDD         |
| 1     | CMP0_IN1      | CMP0_IN1      | CMP1_IN1      | CMP1_IN1      | VDD         |
| 2     | CMP0_IN2      | CMP0_IN2      | CMP1_IN2      | CMP1_IN2      | VDD         |
| 3     | CMP0_IN3      | CMP0_IN3      | CMP1_IN3      | CMP1_IN3      | VDD         |
| 4     | Reserved      | Reserved      | Reserved      | Reserved      | -           |
| 5     | Reserved      | Reserved      | Reserved      | Reserved      | VDD         |
| 6     | Reserved      | Reserved      | Reserved      | Reserved      | -           |
| 7     | Reserved      | Reserved      | Reserved      | Reserved      | -           |

#### 41.1.3 Input references

In the DAC Control register (DCR), when:

- DCR[VRSEL]=0, VREFH0 is selected, which is VDD
- DCR[VRSEL]=1, VREFH1 is selected, which is VREFI (must be in VREFH / VDD\_ANA domain. Note that because of ESD, VDD\_ANA and VDD are in same voltage domain, which means must have same level and ramp up at same time.)

#### 41.1.4 External trigger sources

RRCR0[RR\_EXTTRG\_SEL] controls the trigger source for the CMP. Note that only CMP1 supports multiple options. RRCR0[RR\_EXTTRG\_SEL] is not writeable in CMP0 and only source '0' is available.

**Table 253.** Input connections

| CMP instance | Source number | RR_EXTRG_SEL trigger source |
|--------------|---------------|-----------------------------|
| CMP0         | 0             | LPTMR0                      |
| CMP1         | 0             | Reserved                    |
|              | 1             | CTimer0_MAT0                |
|              | 2             | CTimer0_MAT2                |
|              | 3             | CTimer1_MAT0                |
|              | 4             | CTimer1_MAT2                |
|              | 5             | CTimer2_MAT0                |
|              | 6             | CTimer2_MAT2                |
|              | 7             | LPTMR0                      |
|              | 8             | Reserved (LPTMR1)           |
|              | 9             | PWM0_SM0_MUX_TRIG0          |
|              | 10            | PWM0_SM0_MUX_TRIG1          |
|              | 11            | PWM0_SM1_MUX_TRIG0          |
|              | 12            | PWM0_SM1_MUX_TRIG1          |
|              | 13            | PWM0_SM2_MUX_TRIG0          |
|              | 14            | PWM0_SM2_MUX_TRIG1          |
|              | 15            | Reserved                    |

#### 41.1.5 Functional clock selection

CCR1[FUNC\_CLK\_SEL] selects clock sources as follows:

- 00b - Reserved
- 01b - FRO\_16K
- 10b - Reserved
- 11b - CMPn function clock

See the CMP0/1 clocking in [Figure 52](#) and [Figure 53](#), for details.

#### 41.1.6 Round robin clock selection

RRCR0[RR\_CLK\_SEL] selects clock sources as follows:

- 00b - Reserved
- 01b - FRO\_16K
- 10b - Reserved
- 11b - CMPn function clock

See the CMP0/1 clocking in [Figure 52](#) and [Figure 53](#), for details.

## 41.2 Overview

The LPCMP module provides a circuit to compare two analog input voltages. It includes the following:

- A low power comparator (CMP)
- A DAC
- An analog mux (ANMUX)

See [Block diagram](#) for more information.

LPCMP can operate across the full range of the supply voltage, known as rail-to-rail operation.

DAC is a 256-tap resistor ladder network that provides a selectable voltage reference for applications requiring a voltage reference. DAC divides the supply reference  $V_{in}$  into 256 voltage levels. An 8-bit digital signal input selects the output voltage level, which varies from  $V_{in}$  to  $V_{in}/256$ .

You can select  $V_{in}$  from the following voltage sources:

- VREFH0
- VREFH1

See the Chip-specific LPCMP information for more information on source of VREFH0 and VREFH1.

---

### NOTE

The LPCMP's internal DAC output is available as an on-chip internal signal only and is not available for an external chip pin.

ANMUX allows you to select an analog input signal from among eight channel options. One channel option is the DAC output. Other chip resources are connected to the other channels. See the Chip-specific LPCMP information section for more information. ANMUX can operate across the full range of the supply voltage.

### 41.2.1 Block diagram



Figure 177. Block diagram

### 41.2.2 Features

The features of the LPCMP module include :

- Includes two 8-to-1 channel MUXes to select input signal from eight channels
- Supports multiple operation modes to produce a wide range of outputs such as:
  - Sampled
  - Windowed, which is ideal for certain PWM zero-crossing-detection applications
  - Digitally filtered
- Provides the following advance features for window and sample:

- Window and sample signals can be inverted.
- COUT (comparator output) rising, falling or both edges closes the window.
- COUT level can be defined when window is closed.
- Provides selectable performance levels:
  - Nano-Power mode
  - Low-Power (speed) mode
  - High-Power (speed) mode
- Supports programmable hysteresis control
- Provides a selectable inversion on comparator output
- Uses an external hysteresis at the same time the output filter is used for internal functions
- Provides interrupt and DMA support
- Supports Round Robin Trigger mode
- Includes an 8-bit resolution DAC
- Provides a selectable supply reference source for DAC
- Provides a configurable Low-Power (speed) mode or High-Power (speed) mode for DAC

## 41.3 Functional description

### 41.3.1 Functional block diagram



Figure 178. Functional block diagram

As shown in the block diagram, the functions are:

- Compared two analog input voltages applied to INP and INM, COUT\_RAW is high when the INP input voltage is greater than the INM input voltage, and COUT\_RAW is low when the INP input voltage is less than the INM input voltage.
- The COUT\_RAW signal can be inverted by enabling [CCR1\[COUT\\_INV\]](#).
- The optionally inverted comparator output COUT\_RAW is sampled on every functional clock when you enable the [CCR1\[WINDOW\\_EN\]](#) to generate COUTA. In this case, the comparator output is ignored during time periods when the input voltages are not valid. This is useful when you implement zero-crossing-detection for certain PWM applications.
- The window control block is bypassed when [CCR1\[WINDOW\\_EN\]](#) is disabled.
- The filter block acts as a simple sampler when [CCR1\[FILT\\_CNT\]](#) is set to 01h.
- The filter block acts as a filter based on multiple samples when [CCR1\[FILT\\_CNT\]](#) is set to be greater than 01h.
  - If [CCR1\[SAMPLE\\_EN\]](#) is set to 1, use the external SAMPLE input as the sampling clock.
  - If [CCR1\[SAMPLE\\_EN\]](#) is set to 0, use the divided functional clock as the sampling clock.
- Bypasses the filter block when it is not in use.

```
Bypass_Filter_Block = (FILT_CNT == 0x00) | (~SAMPLE_EN & (FILT_PER == 0x00))
```

- Both COUTA and COUT can be configured as module output CMPO by configuring [CCR1\[COUT\\_SEL\]](#), and are used for different purposes within the system.
- The optionally filtered COUT can be read directly in [CSR\[COUT\]](#).
- The SAMPLE/WINDOW signal can be inverted by setting [CCR1\[WINDOW\\_INV\]](#).
- The SAMPLE/WINDOW signal can be closed by COUT's falling edge and/or rising edge by setting [CCR1\[WINDOW\\_CLS\]](#) in Window mode.
- In Window mode, when window is closed, define the COUTA value as [CCR1\[COUTA\\_OW\]](#) by setting [CCR1\[COUTA\\_OWN\]](#). If [CCR1\[COUTA\\_OWN\]](#) is not set, COUTA holds the last sampled value.

#### NOTE

See the chip configuration section for the source of SAMPLE/WINDOW input.

### 41.3.2 Round-robin trigger mode

You can enable Round-Robin Trigger mode by setting [RRCR0\[RR\\_EN\]](#) to 1. A trigger event initiates a comparison sequence. The next trigger event should not occur before the current sequence completes.

[RRCR1\[FIXP\]](#) and [RRCR1\[FIXCH\]](#) select the reference channel for the plus side mux or the minus side mux.  
[RRCR1\[RR\\_CHnEN\]](#) selects active channels.

When a trigger comes, the analog comparator enables. After the comparison sequence completes, the analog comparator disables again. [RRCR0\[RR\\_INITMOD\]](#) controls the analog stabilization time. Note that RR\_INITMOD\*round robin clock period must be longer than the initialization delay specified in the Comparator and 8-bit DAC electrical specifications section of LPCMP datasheet.

After the stabilization process completes, the round robin manner comparison sequence begins. Sample the comparison result for the selected active channel after [RRCR0\[RR\\_NSAM\]](#) defines the configurable number of operation clocks.

There are ([RR\\_SAMPLE\\_CNT](#) + 1) samples for each channel. With these samples, at least ([RR\\_SAMPLE\\_THRESHOLD](#) + 1) sampled "1" causes the channel's final sample result to be "1"; otherwise, it is "0". Compare the final result with the pre-programmed value.

After all the active channels are sampled/compared, if the comparison result changes from its pre-programmed state, the corresponding flag in RRSR[RR\_CHnF] is set. Write to RRCSR[RR\_CHnOUT] to configure the pre-programmed state for each channel. Update RRCSR[RR\_CHnOUT] to store the last comparison result for each channel. If any flag in RRSR[RR\_CHnF] sets, [CSR\[RRF\]](#) also sets. If [IER\[RRF\\_IE\]](#) sets, an asynchronous interrupt asserts. Note that these flags do not support generating a DMA transfer event.

The following diagram shows the basic flow of this mode. In the diagram, RRCR1[RR\_CH1EN], RRCR1[RR\_CH3EN], and RRCR1[RR\_CH4EN] are 1, so channels #1, #3, and #4 are selected for round-robin depending on their priority setting.

**RRCR0[RR\_NSAM]** sets to 2'b01, so you can sample one clock later the comparison result of the selected channel. After you compare the channel #4, the result is sampled, and round-robin ends. If any of the comparison results from channel #1, #3, or #4 changed from their programmed value (written to RRCSR[RR\_CH1OUT], RRCSR[RR\_CH3OUT], and RRCSR[RR\_CH4OUT]), generates an interrupt . Software can then poll RRCSR[RR\_CHnF] to see which channel input(s) changed value.



Figure 179. Trigger mode

The table below shows the channel decode in both Functional mode and Trigger mode. Other cases not in the table are illegal.

Table 254. CMP channel decode in functional mode and round-robin trigger mode

| Mode            | RR_EN | PSEL[2:0] | MSEL[2:0] | FIXP           | FIXCH[2:0] | RR_CHxN | INP                            | INM                            | CMP Behavior                                                |
|-----------------|-------|-----------|-----------|----------------|------------|---------|--------------------------------|--------------------------------|-------------------------------------------------------------|
| Functional mode | 0     | 0 to 7    | 0 to 7    | x <sup>1</sup> | x          | x       | Channel decoded from PSEL[2:0] | Channel decoded from MSEL[2:0] | Compare the channel 0 to 7 with channel 0 to 7 <sup>2</sup> |
| Trigger mode    | 1     | x         | x         | 0              | 0 to 7     | 0 to 7  | Channel fixed by FIXCH[2:0]    | Channel sweep (RR_CHxN)        | Sweep the channel 0 to 7 with a fixed channel (0 to 7)      |
|                 |       | x         | x         | 1              | 0 to 7     | 0 to 7  | Channel sweep (RR_CHxN)        | Channel fixed by FIXCH[2:0]    | Sweep the channel 0 to 7 with a fixed channel (0 to 7)      |

1. "x" means "don't care"

2. PSEL should not be same as MSEL.

### 41.3.3 Low-pass filter mode

The low-pass filter mode operates on an unfiltered, optionally inverted comparator output COUTA, and generates the filtered and synchronized output COUT. You can configure both COUTA and COUT as module outputs and use for different purposes within the system.

Synchronization and edge detection determine the bit values of status register. They also apply to COUT for all sampling and windowed modes. You can perform filtering using an internal timebase defined by [CCR1\[FILT\\_PER\]](#), or use an external sample input to determine sample time.

The need for digital filtering and the amount of filtering depends on your requirements. Filtering can become more useful in the absence of an external hysteresis circuit. Without external hysteresis, generate a high-frequency oscillations at COUTA when the selected INM and INP input voltages differ by less than the offset voltage of the differential comparator.

#### 41.3.3.1 Enabling low-pass filter mode

You can enable low-pass filter mode by setting the following:

- [CCR1\[FILT\\_CNT\]](#) > 01h
- [CCR1\[FILT\\_PER\]](#) to a nonzero value or writing 1 to [CCR1\[SAMPLE\\_EN\]](#).

If you use the divided functional clock to drive the low-pass filter, it samples COUTA every [CCR1\[FILT\\_PER\]](#) functional clock cycle.

If [CCR1\[SAMPLE\\_EN\]](#) is set to 1, the low-pass filter samples COUTA on each positive transition of the sample input. The output state of the filter changes when all the consecutive [CCR1\[FILT\\_CNT\]](#) samples agree that the output value has changed.

#### 41.3.3.2 Latency issues

Program the value of [CCR1\[FILT\\_PER\]](#) or sample period such that the sampling period is longer than the period of the expected noise, ensuring that a given noise spike corrupts only one sample. You must choose the value of [CCR1\[FILT\\_CNT\]](#) to reduce the probability of noisy samples causing an incorrect transition to recognize. The probability of an incorrect transition is defined as the probability of an incorrect sample raised to the power of [CCR1\[FILT\\_CNT\]](#).

You must trade off the values of [CCR1\[FILT\\_PER\]](#) or sample period and [CCR1\[FILT\\_CNT\]](#) against the need for minimal latency in recognizing actual comparator output transitions. The probability of detecting an actual output change within the nominal latency is the probability of a correct sample raised to the power of [CCR1\[FILT\\_CNT\]](#).

[Table 256](#) summarizes maximum latency values for the various modes of operation in the absence of noise. Filtering latency restarts each time the noise masks an actual output transition.

#### 41.3.4 Low power mode operation

Below table introduces the mode of operation of lower power.

**Table 255.** Low power mode operation

| Mode of operation | Description                                                            |
|-------------------|------------------------------------------------------------------------|
| Wait              | LPCMP can operate normally with window and filter function.            |
| Deep Sleep        | LPCMP can operate only in Continuous mode or Round-robin trigger mode. |

#### 41.3.5 Functional modes

You can combine the comparator window and filter features as shown in the following table.

**Table 256.** Functional modes

| Mode # | CMP_EN | WINDOW_EN | SAMPLE_EN | FILT_CNT | FILT_PER | Operation                                    | Maximum latency <sup>1</sup> |
|--------|--------|-----------|-----------|----------|----------|----------------------------------------------|------------------------------|
| 1      | 0      | X         | X         | X        | X        | See the <a href="#">Disabled mode (#1)</a> . | N/A                          |

*Table continues on the next page...*

Table 256. Functional modes (continued)

| Mode #                                                                                      | CMP_EN | WINDOW_EN | SAMPLE_EN | FILT_CNT | FILT_PER | Operation                                         | Maximum latency <sup>1</sup>                            |
|---------------------------------------------------------------------------------------------|--------|-----------|-----------|----------|----------|---------------------------------------------------|---------------------------------------------------------|
| 2A                                                                                          | 1      | 0         | X         | 0x00     | X        | See the Continuous mode (#2A and #2B).            | $T_{PD}$                                                |
| 2B                                                                                          | 1      | 0         | 0         | X        | 0x00     |                                                   |                                                         |
| 3A                                                                                          | 1      | 0         | 1         | 0x01     | X        | See the Sampled, non-filtered mode (#3A and #3B). | $T_{PD} + T_{SAMPLE} + T_{per}$                         |
| 3B                                                                                          | 1      | 0         | 0         | 0x01     | > 0x00   |                                                   |                                                         |
| 4A                                                                                          | 1      | 0         | 1         | > 0x01   | X        | See the Sampled, filtered mode (#4A and #4B).     | $T_{PD} + (FILT\_CNT * T_{SAMPLE}) + T_{SAMPLE}$        |
| 4B                                                                                          | 1      | 0         | 0         | > 0x01   | > 0x00   |                                                   |                                                         |
| 5A                                                                                          | 1      | 1         | 0         | 0x00     | X        | See the Windowed mode (#5A and #5B).              | $T_{PD} + 2T_{per}$                                     |
| 5B                                                                                          | 1      | 1         | 0         | X        | 0x00     |                                                   |                                                         |
| 6                                                                                           | 1      | 1         | 0         | 0x01     | > 0x00   | See the Windowed/Resampled mode (#6).             | $T_{PD} + (FILT\_PER * T_{per}) + 3T_{per}$             |
| 7                                                                                           | 1      | 1         | 0         | > 0x01   | > 0x00   | See the Windowed/Filtered mode (#7).              | $T_{PD} + (FILT\_CNT * FILT\_PER x T_{per}) + 3T_{per}$ |
| All other combinations of CMP_EN, WINDOW_EN, SAMPLE_EN, FILT_CNT, and FILT_PER are illegal. |        |           |           |          |          |                                                   |                                                         |

1.  $T_{PD}$  represents the intrinsic delay of the analog component plus the polarity select logic.  $T_{SAMPLE}$  is the clock period of the external sample clock.  $T_{per}$  is the period of the functional clock.

#### 41.3.5.1 Disabled mode (#1)

In this mode:

- The analog comparator is non-functional and consumes no power.
- [CSR\[COUT\]](#) and CMPO are the same as [CCR1\[COUT\\_INV\]](#).

#### 41.3.5.2 Continuous mode (#2A and #2B)



Figure 180. Comparator operation in continuous mode

COUT\_RAW is optionally inverted in this mode but is not subject to external sampling or filtering. Both window control and filter blocks bypass completely, and [CSR\[COUT\]](#) updates continuously. The path from comparator input pins to output pins operates in a combinational (unclocked) mode. COUT and COUTA are identical in this mode.

For cases where a comparator drives a fault input, you must configure it to operate in Continuous mode so that an external fault can immediately pass to the target fault circuitry through the comparator.

#### 41.3.5.3 Sampled, non-filtered mode (#3A and #3B)



Figure 181. Sampled, non-filtered (#3A): sampling point externally driven



Figure 182. Sampled, Non-Filtered (#3B): sampling interval internally derived

In this mode, the path from analog inputs to COUTA is combinational (unclocked). Windowing control bypasses completely. You can sample COUTA whenever you detect a rising edge on the sampling clock.

The difference in two operation modes (#3A and #3B) of sampled, non-filtered mode is that how you drive the clock to the filter block. In #3A, the clock to filter block drives externally, and in #3B, the clock to filter block drives internally.

The filter block has no other function than sample or hold of the comparator output in this mode.

The following figure shows the comparator operation in this mode, assuming that the polarity select sets to a non-inverting state.



Figure 183. Sampled, Non-Filtered mode timing diagram

#### 41.3.5.4 Sampled, filtered mode (#4A and #4B)



Figure 184. Sampled, filtered (#4A): sampling point externally driven



Figure 185. Sampled, filtered (#4B): sampling point internally derived

In this mode, the path from the analog inputs to COUTA is combinational(unclocked). Windowing control bypasses completely. You can sample COUTA whenever you detect a rising edge on the sampling clock.

The only difference in operation between sampled, non-filtered (#3A) mode and sampled, filtered (#4A) mode is that CCR1[FILT\_CNT] is larger than 1, which activates filter operation.

The only difference in operation between sampled, non-filtered (#3B) mode and sampled, filtered (#4B) mode is that CCR1[FILT\_CNT] is larger than 1, which activates filter operation.

#### 41.3.5.5 Windowed mode (#5A and #5B)



Figure 186. Windowed mode

The functional clock clocks COUTA whenever you enable the window in this mode. The last latched value holds after you disable the window and the filter block is bypassed.

The following figure shows the comparator operation in this mode, ignoring the latency of the analog comparator, polarity select, and window control block. The polarity select sets to a non-inverting state.

COUTA may lag the analog inputs by up to two functional clock cycles plus the combinational path delay through the comparator and polarity select logic in the actual operation.



Figure 187. Windowed mode timing diagram

The following figure shows that if [CCR1\[COUTA\\_OWEN\]](#) becomes 1, you can define COUTA level as [CCR1\[COUTA\\_OWI\]](#), after you closes the window.



Figure 188. Windowed mode timing diagram with user defined value 0 outside window



Figure 189. Windowed mode timing diagram with user defined value 1 outside window

If [CCR1\[WINDOW\\_CLS\]](#) becomes 1, you can define the COUT event (rising edge, falling edge or both edges that [CCR1\[EVT\\_SEL\]](#) selects) to close the window. The external window signal has to go to zero and back to one to enable the internal window again. The following figure shows an example that COUT rising edge closes the internal window.



Figure 190. Windowed mode timing diagram with COUT rising edge close window

The following figure shows that if [CCR1\[WINDOW\\_INV\]](#) becomes 1, you can invert the window signal before you use it.



Figure 191. Windowed mode timing diagram with window signal inverted

#### 41.3.5.6 Windowed/Resampled mode (#6)



Figure 192. Windowed/Resampled mode

This mode of operation results in an unfiltered string of comparator samples where CCR1[FILT\_PER] and the functional clock rate determines the interval between the samples. The following section shows that the configuration for this mode is virtually identical to that for the Windowed/Filtered mode. The only difference is that the value of CCR1[FILT\_CNT] must be 1 in this mode.

The following figure uses the same input stimulus shown in Figure 187, and adds resampling of COUTA to generate COUT. The arrows in the figure indicate the time points at which the samples are taken. You can ignore prop delays and latency for clarity.



Figure 193. Windowed/Resampled mode operation

This example demonstrates the operation of the comparator in Windowed/Resampled mode, and does not reflect any specific application. Based on the sampling rate and window placement, COUT may not see zero-crossing events that the analog comparator detects. You must carefully consider the sampling period and/or window placement for a given application.

#### 41.3.5.7 Windowed/Filtered mode (#7)



Figure 194. Windowed/Filtered mode

The only difference in operation between [Windowed/Resampled mode \(#6\)](#) and [Windowed/Filtered mode \(#7\)](#) is that [CCR1\[FILT\\_CNT\]](#) is >1, which activates filter operation.

This mode is the most complex mode of operation for the comparator block, as it utilizes both windowing and filtering features. It also has the highest latency of any of the modes. This is approximately: up to 2 peripheral clock synchronization in the window function + (([CCR1\[FILT\\_CNT\]](#) x [CCR1\[FILT\\_PER\]](#)) + 1) x peripheral clock for the filter function.

#### 41.3.6 DMA

After DMA is enabled by writing 1 to [CCR1\[DMA\\_EN\]](#) and interrupt is enabled by writing 1 to [IER\[CFR\\_IE\]](#), [IER\[CFF\\_IE\]](#), or both, the corresponding change on COUT forces a DMA transfer request rather than a CPU interrupt. After the DMA completes the transfer, it sends a transfer completing indicator signal that deasserts the DMA transfer request and clears the flags (both [CSR\[CFR\]](#) and [CSR\[CFF\]](#)) to allow a subsequent change on comparator output to occur and forces another DMA request.

The comparator can remain functional in Deep Sleep modes if [CCR0\[CMP\\_STOP\\_EN\]](#) becomes 1.

A DMA transfer request wakes up the system from Deep Sleep mode. After completing the data transfer, the system goes back again to Deep Sleep mode. See the DMA chapters in this document for more information on the asynchronous DMA function.

#### 41.3.7 Clocking

LPCMP requires the following clocks to operate:

Table 257. LPCMP clocks

| Type of clock | Description                             |
|---------------|-----------------------------------------|
| Bus           | Controls the access to LPCMP registers. |

*Table continues on the next page...*

Table 257. LPCMP clocks (continued)

| Type of clock            | Description                                                                                                                                                                                                                               |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Functional               | Controls window/filter function. LPCMP configures <a href="#">CCR1[FUNC_CLK_SEL]</a> to select one from the four functional clock sources. See the Chip-specific LPCMP information for more on the functional clock source information.   |
| Round-robin clock (RCLK) | Controls Round-robin trigger mode. LPCMP configures <a href="#">CCR1[RR_CLK_SEL]</a> to select one from the four round-robin clock sources. See the Chip-specific LPCMP information for more on the round robin clock source information. |

#### 41.3.8 Resets

The global chip reset signal resets LPCMP.

#### 41.3.9 Interrupts

After the corresponding [IER](#) becomes 1, [CSR\[CFR\]](#), [CSR\[CFF\]](#), and [CSR\[RRF\]](#) can generate an interrupt, assuming that [CCR1\[DMA\\_EN\]](#) is not 1. You can clear either the flag or [IER](#) to deassert the interrupt.

### 41.4 External signal descriptions

Below table introduces external signals.

Table 258. External signal descriptions

| Signal                | Description                                                                                                 | I/O |
|-----------------------|-------------------------------------------------------------------------------------------------------------|-----|
| CMPO                  | Filtered or unfiltered comparator output                                                                    | O   |
| Input_Analog_Channels | Analog input channels (see the chip-specific information for more on the connections).                      | I   |
| VREFH_EXT             | External reference voltage for the CMP-DAC (see the chip-specific information for more on the connections). | I   |
| RR_ACTIVE             | Round-robin trigger mode enabled.                                                                           | O   |

### 41.5 Initialization

You can enable LPCMP by writing 1 to [CCR0\[CMP\\_EN\]](#), and then configuring the control registers ([CCR1](#), [CCR2](#), [DCR](#), and so on).

To disable LPCMP, write 0 to [CCR0\[CMP\\_EN\]](#). Switching operation modes or changing control register fields on-the-fly (when [CCR0\[CMP\\_EN\]](#) is set to 1) may cause noise on the COUT or COUTA signals. To avoid unwanted signal noise, you must ensure to disable the module before switching modes or changing control fields.

The time required to stabilize COUT is the power-on delay of the comparators plus the largest propagation delay from a selected analog source through the analog comparator, windowing function, and filter (see the Comparator and 8-bit DAC electrical specifications section of LPCMP datasheet for more information on propagation delay and power-up delay). [Table 256](#) specifies the delay that the windowing and filter function causes.

During operation, you must always consider the propagation delay of the selected data paths. It can take many functional clock cycles for COUT and [CSR\[CFR\]/CSR\[CFF\]](#) to reflect an input change or a configuration change to one of the components involved in the data path.

## 41.6 Application information

### 41.6.1 Round-robin trigger mode programing recommendation

Configure the Round-robin trigger mode as follows:

1. Configure [RRCR0\[RR\\_CLK\\_SEL\]](#) to select the RR clock source.
2. Configure the comparison cycles by [RRCR0\[RR\\_NSAM\]](#). Note: It is a mandatory request that the round robin cycling period must set longer than the time that all the active channels complete the specified comparison cycles set by [RRCR0\[RR\\_NSAM\]](#).
3. Configure CMP initialization delay by [RRCR0\[RR\\_INITMOD\]](#). Note: In programming [RRCR0\[RR\\_INITMOD\]](#), the RR\_INITMOD x round robin clock period must be longer than the initialization delay, see the LPCMP datasheet for more information.
4. Configure [RRCR0\[RR\\_SAMPLE\\_CNT\]](#) and [RRCR0\[RR\\_SAMPLE\\_THRESHOLD\]](#).
5. Configure [RRCR0\[RR\\_TRG\\_SEL\]](#) to select the trigger from internal or external.
6. Enable [RRCR2\[RR\\_TIMER\\_EN\]](#) and configure [RRCR2\[RR\\_TIMER\\_RELOAD\]](#) according to the round robin clock frequency, if using an internal trigger.
7. Configure [RRCR1\[FIXP\]](#) to select the fixed port of CMP and [RRCR1\[FIXCH\]](#) to select the fixed channel.
8. Configure channels for comparison by [RRCR1\[RR\\_CHnEN\]](#).
9. Write [RRCR1\[RR\\_CHnOUT\]](#) to define the pre-set state of channel n.
10. Clear channel flags [RRCSR\[RR\\_CHnF\]](#).
11. Enable round robin interrupt by [IER\[RRF\\_IE\]](#) (disable [IER\[CFR\\_IE\]](#) and [IER\[CFF\\_IE\]](#)).
12. Enable round-robin trigger mode by setting [RRCR0\[RR\\_EN\]](#) to 1.

### 41.6.2 Round-robin clock (RCLK) frequency requirement

#### (1) RCLK high frequency limit

RCLK high frequency limit depends on two facts:

1. The analog CMP and DAC initialization time (see the chip data sheet for more information on the initialization time.)
  - [RRCR0\[RR\\_INITMOD\]](#) provides a maximum 63 RCLK cycles for the analog CMP and DAC initialization.
  - RCLK must be slow to assure:  $63 * (1/f_{RCLK}) > T_{\text{initialization}}$ , where  $f_{RCLK}$  is in MHz, and  $T_{\text{initialization}}$  is in microsecond.
  - so  $f_{RCLK} < 63 / T_{\text{initialization}}$
  - Example:  $T_{\text{initialization}} = 40 \mu\text{s}$ , then  $f_{RCLK}$  should be smaller than 1.575 MHz.
2. The analog CMP propagation delay (see the Comparator and 8-bit DAC electrical specifications section of LPCMP datasheet for more information on the CMP propagation delay.)
  - [RRCR0\[RR\\_NSAM\]](#) provides a maximum 4 RCLK cycles for the analog CMP propagation delay.
  - RCLK must be slow to assure:  $4 * (1/f_{RCLK}) > T_{\text{propagation}}$ , where  $f_{RCLK}$  is in MHz, and  $T_{\text{propagation}}$  is in microsecond.
  - $f_{RCLK} < 4 / T_{\text{propagation}}$
  - Example:  $T_{\text{propagation}} = 0.1 \mu\text{s}$ , then  $f_{RCLK}$  must be smaller than 40 MHz.

#### (2) RCLK low frequency limit

In theory, RCLK frequency has no low limit. But the lower the RCLK frequency, the longer the scan time. Therefore, the lower limit of the RCLK frequency depends on the system application.

## 41.7 LPCMP register descriptions

The memory map comprises of 32-bit aligned registers, which you can access via 8-, 16- or 32-bit reads and 32-bit write. Attempted accesses using unsupported write data sizes, writes to read-only resources, or to reserved spaces terminate with an error. Read access to reserved address generates a transfer error and the read data bus shows all 0s.

### 41.7.1 LPCMP memory map

CMP0 base address: 400B\_1000h

CMP1 base address: 400B\_2000h

| Offset | Register                               | Width<br>(In bits) | Access | Reset value |
|--------|----------------------------------------|--------------------|--------|-------------|
| 4h     | Parameter (PARAM)                      | 32                 | R      | 0000_0002h  |
| 8h     | Comparator Control Register 0 (CCR0)   | 32                 | RW     | 0000_0002h  |
| Ch     | Comparator Control Register 1 (CCR1)   | 32                 | RW     | 0000_0000h  |
| 10h    | Comparator Control Register 2 (CCR2)   | 32                 | RW     | 0000_0000h  |
| 18h    | DAC Control (DCR)                      | 32                 | RW     | 0000_0000h  |
| 1Ch    | Interrupt Enable (IER)                 | 32                 | RW     | 0000_0000h  |
| 20h    | Comparator Status (CSR)                | 32                 | RW     | 0000_0000h  |
| 24h    | Round Robin Control Register 0 (RRCR0) | 32                 | RW     | 0000_0000h  |
| 28h    | Round Robin Control Register 1 (RRCR1) | 32                 | RW     | 0000_0000h  |
| 2Ch    | Round Robin Control and Status (RRCSR) | 32                 | RW     | 0000_0000h  |
| 30h    | Round Robin Status (RRSR)              | 32                 | RW     | 0000_0000h  |
| 38h    | Round Robin Control Register 2 (RRCR2) | 32                 | RW     | 0000_0000h  |

### 41.7.2 Parameter (PARAM)

#### Offset

| Register | Offset |
|----------|--------|
| PARAM    | 4h     |

#### Function

Contains parameter values that are implemented in the module.

**Diagram**

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

**Fields**

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-4<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                    |
| 3-0<br>DAC_RES | <p>DAC Resolution</p> <p>Indicates supported DAC resolutions.</p> <p><b>NOTE</b><br/>All other bit field values are reserved.</p> <ul style="list-style-type: none"> <li>0000b - 4-bit DAC</li> <li>0001b - 6-bit DAC</li> <li>0010b - 8-bit DAC</li> <li>0011b - 10-bit DAC</li> <li>0100b - 12-bit DAC</li> <li>0101b - 14-bit DAC</li> <li>0110b - 16-bit DAC</li> </ul> |

**41.7.3 Comparator Control Register 0 (CCR0)****Offset**

| Register | Offset |
|----------|--------|
| CCR0     | 8h     |

**Function**

Contains configuration options for enabling the analog comparator.

**Diagram**

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16             |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------|
| R     | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0              |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0              |
| R     | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CMP_<br>STO... |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CMP_<br>EN     |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0              |

**Fields**

| Field                | Function                                                                                                                                                                                                                                                                                                                                 |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2<br>—            | Reserved                                                                                                                                                                                                                                                                                                                                 |
| 1<br>CMP_STOP_E<br>N | <p>Comparator Deep Sleep Mode Enable</p> <p>Enables the analog comparator or the DAC when the module is in Deep Sleep mode.</p> <p><b>NOTE</b><br/>This field has no effect in Round-robin Trigger mode.</p> <p>0b - Disables the analog comparator regardless of CMP_EN.</p> <p>1b - Allows CMP_EN to enable the analog comparator.</p> |
| 0<br>CMP_EN          | <p>Comparator Enable</p> <p>Enables the analog comparator.</p> <p>0b - Disable (The analog logic remains off and consumes no power.)</p> <p>1b - Enable</p>                                                                                                                                                                              |

**41.7.4 Comparator Control Register 1 (CCR1)****Offset**

| Register | Offset |
|----------|--------|
| CCR1     | Ch     |

**Function**

Contains configuration options for the comparator operation, such as enabling Sampling or Windowing mode.

**NOTE**

You cannot enable Sampling and Windowing modes both at the same time. Sampling mode takes precedence over Windowing mode. If you write 1 to both **SAMPLE\_EN** and **WINDOW\_EN**, only **SAMPLE\_EN** becomes 1.

**Diagram**

| Bits  | 31       | 30          | 29 | 28      | 27          | 26          | 25        | 24          | 23       | 22       | 21       | 20       | 19         | 18          | 17 | 16 |
|-------|----------|-------------|----|---------|-------------|-------------|-----------|-------------|----------|----------|----------|----------|------------|-------------|----|----|
| R     | FILT_PER |             |    |         |             |             |           |             |          |          | 0        | FILT_CNT |            |             |    |    |
| W     |          |             |    |         |             |             |           |             |          |          |          |          |            |             |    |    |
| Reset | 0        | 0           | 0  | 0       | 0           | 0           | 0         | 0           | 0        | 0        | 0        | 0        | 0          | 0           | 0  | 0  |
| Bits  | 15       | 14          | 13 | 12      | 11          | 10          | 9         | 8           | 7        | 6        | 5        | 4        | 3          | 2           | 1  | 0  |
| R     | 0        | FUNC_CLK_SE |    | EVT_SEL | WIND_OW.... | WIND_OW.... | COUT_A_OW | COUT_A_O... | COUT_PEN | COUT_SEL | COUT_INV | DMA_EN   | SAMPLE.... | WIND_OW.... |    |    |
| W     |          |             |    |         | 0           | 0           | 0         | 0           | 0        | 0        | 0        | 0        | 0          | 0           | 0  | 0  |
| Reset | 0        | 0           | 0  | 0       | 0           | 0           | 0         | 0           | 0        | 0        | 0        | 0        | 0          | 0           | 0  | 0  |

**Fields**

| Field             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24<br>FILT_PER | <p>Filter Sample Period</p> <p>Specifies the sampling period (in functional clock cycles) of the comparator output filter. Programming this field to 00h bypasses the filter. See <a href="#">Functional description</a> for more information on filter programming and latency.</p> <p><b>NOTE</b><br/>FILT_PER has no effect in Sampling mode (<a href="#">CCR1[SAMPLE_EN] = 1</a>).</p>                                                                                                                                                                                                                                                                                                     |
| 23-19<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 18-16<br>FILT_CNT | <p>Filter Sample Count</p> <p>Specifies the number of consecutive samples that must agree before the comparator output filter accepts the sample as a new valid output state. See <a href="#">Functional description</a> for more information on filter programming and latency.</p> <ul style="list-style-type: none"> <li>000b - Filter is bypassed: COUT = COUTA</li> <li>001b - 1 consecutive sample (Comparator output is simply sampled.)</li> <li>010b - 2 consecutive samples</li> <li>011b - 3 consecutive samples</li> <li>100b - 4 consecutive samples</li> <li>101b - 5 consecutive samples</li> <li>110b - 6 consecutive samples</li> <li>111b - 7 consecutive samples</li> </ul> |
| 15-14<br>—        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 13-12             | Functional Clock Source Select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FUNC_CLK_SEL     | <p>Selects which clock source is used for the functional clock. See the Chip-specific LPCMP information for more on the functional clock source information.</p> <p>00b - Select functional clock source 0<br/>01b - Select functional clock source 1<br/>10b - Select functional clock source 2<br/>11b - Select functional clock source 3</p>                                                                                                                         |
| 11-10<br>EVT_SEL | <p>COUT Event Select</p> <p>Selects which COUT signal edge (rising, falling, or both) defines a COUT event.</p> <p style="text-align: center;"><b>NOTE</b><br/>Valid only in Windowing mode.</p> <p>00b - Rising edge<br/>01b - Falling edge<br/>1xb - Both edges</p>                                                                                                                                                                                                   |
| 9<br>WINDOW_CLS  | <p>COUT Event Window Close</p> <p>Enables a COUT event (defined as a COUT rising edge, falling edge, or both) to close an active window. See <a href="#">EVT_SEL</a> to configure the COUT event.</p> <p style="text-align: center;"><b>NOTE</b><br/>The WINDOW signal has to go to zero and back to one again to re-activate the window.<br/>Valid only in Windowing mode.</p> <p>0b - COUT event cannot close the window<br/>1b - COUT event can close the window</p> |
| 8<br>WINDOW_INV  | <p>WINDOW/SAMPLE Signal Invert</p> <p>Inverts the window/sample signal.</p> <p>0b - Do not invert<br/>1b - Invert</p>                                                                                                                                                                                                                                                                                                                                                   |
| 7<br>COUTA_OW    | <p>COUTA Output Level for Closed Window</p> <p>Defines the COUTA signal value when the window is closed.</p> <p style="text-align: center;"><b>NOTE</b><br/>Valid only in Windowing mode and when COUTA_OWN=1.</p> <p>0b - COUTA is 0<br/>1b - COUTA is 1</p>                                                                                                                                                                                                           |
| 6                | COUTA_OW Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| COUTA_OWN      | <p>Enables the COUTA signal value to be defined by <a href="#">COUTA_OW</a> when the window is closed.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>Valid only in Windowing mode.</p> <p>0b - COUTA holds the last sampled value.<br/>1b - Enables the COUTA signal value to be defined by COUTA_OW.</p>                                                              |
| 5<br>COUT_PEN  | <p>Comparator Output Pin Enable</p> <p>Enables the comparator output to become an available signal option for a selected package pin.</p> <p>0b - Not available<br/>1b - Available</p>                                                                                                                                                                                         |
| 4<br>COUT_SEL  | <p>Comparator Output Select</p> <p>Selects which comparator output option, COUT or COUTA, to use for CMPO.</p> <p>0b - Use COUT (filtered)<br/>1b - Use COUTA (unfiltered)</p>                                                                                                                                                                                                 |
| 3<br>COUT_INV  | <p>Comparator Invert</p> <p>Selects the polarity of the analog comparator function, affecting the value driven to the COUT output (on both the chip pin and as <a href="#">CSR[COUT]</a>) when <a href="#">CCR0[ CMP_EN]</a> is 0.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>COUT_INV has no effect in Trigger mode.</p> <p>0b - Do not invert<br/>1b - Invert</p> |
| 2<br>DMA_EN    | <p>DMA Enable</p> <p>Enables DMA transfers triggered from the LPCMP module. After this field and the corresponding interrupt enable field becomes 1, a DMA request is asserted when <a href="#">CFR</a> or <a href="#">CFF</a> becomes 1.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                              |
| 1<br>SAMPLE_EN | <p>Sampling Enable</p> <p>Enables Sampling mode.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                                                                                                                                       |
| 0<br>WINDOW_EN | <p>Windowing Enable</p> <p>Enables Windowing mode.</p>                                                                                                                                                                                                                                                                                                                         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                        |
|-------|---------------------------------------------------------------------------------------------------------------------------------|
|       | <p style="text-align: center;"><b>NOTE</b></p> <p>Valid only when <b>SAMPLE_EN</b> = 0.</p> <p>0b - Disable<br/>1b - Enable</p> |

#### 41.7.5 Comparator Control Register 2 (CCR2)

##### Offset

| Register | Offset |
|----------|--------|
| CCR2     | 10h    |

##### Function

Contains the configuration options for the comparator operation, such as selecting the plus and minus comparator inputs and the hysteresis levels.

##### Diagram



##### Fields

| Field | Function                                                                                                      |
|-------|---------------------------------------------------------------------------------------------------------------|
| 31-23 | Reserved                                                                                                      |
| —     |                                                                                                               |
| 22-20 | Minus Input MUX Select                                                                                        |
| MSEL  | Selects the input used for the negative mux. See the chip-specific LPCMP information for more on connections. |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                | <p style="text-align: center;"><b>NOTE</b></p> <p>MSEL has no effect in Trigger mode.</p> <p>000b - Input 0m<br/>     001b - Input 1m<br/>     010b - Input 2m<br/>     011b - Input 3m<br/>     100b - Input 4m<br/>     101b - Input 5m<br/>     110b - Reserved<br/>     111b - Internal DAC output</p>                                                                                                                                                   |
| 19             | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| —              |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 18-16<br>PSEL  | <p>Plus Input MUX Select</p> <p>Selects the input used for the positive mux. See the chip-specific LPCMP information for more on connections.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>PSEL has no effect in Trigger mode.</p> <p>000b - Input 0p<br/>     001b - Input 1p<br/>     010b - Input 2p<br/>     011b - Input 3p<br/>     100b - Input 4p<br/>     101b - Input 5p<br/>     110b - Reserved<br/>     111b - Internal DAC output</p> |
| 15-6           | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| —              |                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5-4<br>HYSTCTR | <p>Comparator Hysteresis Control</p> <p>Selects the level of internally generated hysteresis for the comparator output.</p> <p style="text-align: center;"><b>NOTE</b></p> <p>This applies to the comparator hard block.</p>                                                                                                                                                                                                                                 |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               | 00b - Level 0: Analog comparator hysteresis 0 mV.<br>01b - Level 1: Analog comparator hysteresis 10 mV.<br>10b - Level 2: Analog comparator hysteresis 20 mV.<br>11b - Level 3: Analog comparator hysteresis 30 mV.                                                                                                                                                                                         |
| 3-2<br>—      | Reserved                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1<br>CMP_NPMD | <b>CMP Nano Power Mode Select</b><br>Enables Nano Power mode for the comparator.<br>0b - Disables CMP Nano power mode. CCR2[CMP_HPMD] determines the mode for the comparator.<br>1b - Enables CMP Nano power mode.                                                                                                                                                                                          |
| 0<br>CMP_HPMD | <b>CMP High Power Mode Select</b><br>Selects Low or High Power(Speed) mode for the comparator.<br><div style="text-align: center;"> <b>NOTE</b><br/>           Valid only when not in Nano Power mode (<a href="#">CMP_NPMD = 0</a>).         </div> <div style="margin-top: 10px;">           0b - Low power (speed) comparison mode<br/>           1b - High power (speed) comparison mode         </div> |

#### 41.7.6 DAC Control (DCR)

##### Offset

| Register | Offset |
|----------|--------|
| DCR      | 18h    |

##### Function

Contains the configuration options to enable the DAC.

**Diagram**

|       |    |    |    |    |    |    |    |    |      |    |    |    |          |    |         |        |
|-------|----|----|----|----|----|----|----|----|------|----|----|----|----------|----|---------|--------|
| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22 | 21 | 20 | 19       | 18 | 17      | 16     |
| R     |    |    |    |    | 0  |    |    |    |      |    |    |    | DAC_DATA |    |         |        |
| W     |    |    |    |    |    |    |    |    |      |    |    |    |          |    |         |        |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0  | 0        | 0  | 0       | 0      |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7    | 6  | 5  | 4  | 3        | 2  | 1       | 0      |
| R     |    |    |    |    | 0  |    |    |    | VRSE |    |    |    | 0        |    | DAC_HPM | DAC_EN |
| W     |    |    |    |    |    |    |    |    | L    |    |    |    |          |    |         |        |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0  | 0        | 0  | 0       | 0      |

**Fields**

| Field             | Function                                                                                                                                                                                                                                                                  |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-24<br>—        | Reserved                                                                                                                                                                                                                                                                  |
| 23-16<br>DAC_DATA | <p>DAC Output Voltage Select</p> <p>Selects the DAC output (DACO) voltage from one of 256 distinct levels by configuring the value of DAC_DATA. The DACO ranges from Vin/256 to Vin.</p> <p><b>NOTE</b><br/> <math>DACO = (Vin/256) * (DAC\_DATA + 1)</math></p>          |
| 15-9<br>—         | Reserved                                                                                                                                                                                                                                                                  |
| 8<br>VRSEL        | <p>DAC Reference High Voltage Source Select</p> <p>Selects the high voltage reference source for the Vin supply of the DAC's resistor ladder network. See the chip-specific LPCMP information for the source of vrefh0 and vrefh1.</p> <p>0b - VREFH0<br/>1b - VREFH1</p> |
| 7-2<br>—          | Reserved                                                                                                                                                                                                                                                                  |
| 1<br>DAC_HPM      | <p>DAC High Power Mode</p> <p>Enables the DAC high power mode.</p> <p>0b - Disable<br/>1b - Enable</p>                                                                                                                                                                    |
| 0<br>DAC_EN       | <p>DAC Enable</p> <p>Enables the DAC. When disabled, power-down the DAC to conserve power.</p>                                                                                                                                                                            |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function     |
|-------|--------------|
|       | 0b - Disable |
|       | 1b - Enable  |

#### 41.7.7 Interrupt Enable (IER)

##### Offset

| Register | Offset |
|----------|--------|
| IER      | 1Ch    |

##### Function

Provides enable fields for the comparator and round-robin flag interrupts.

##### Diagram



##### Fields

| Field       | Function                                                                                                                                                                                                                                         |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-3<br>—   | Reserved                                                                                                                                                                                                                                         |
| 2<br>RRF_IE | Round-Robin Flag Interrupt Enable<br>Enables or disables the round-robin flag interrupt.<br>0b - Disables the round-robin flag interrupt.<br>1b - Enables the round-robin flag interrupt when the comparison result changes for a given channel. |
| 1           | Comparator Flag Falling Interrupt Enable                                                                                                                                                                                                         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                          |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CFF_IE      | Enables or disables the comparator flag falling interrupt.<br>0b - Disables the comparator flag falling interrupt.<br>1b - Enables the comparator flag falling interrupt when CFF is set.                                         |
| 0<br>CFR_IE | Comparator Flag Rising Interrupt Enable<br>Enables or disables the comparator flag rising interrupt.<br>0b - Disables the comparator flag rising interrupt.<br>1b - Enables the comparator flag rising interrupt when CFR is set. |

#### 41.7.8 Comparator Status (CSR)

##### Offset

| Register | Offset |
|----------|--------|
| CSR      | 20h    |

##### Function

Indicates comparator status, including [COUT](#), [CFF](#), [CFR](#), and [RRF](#).

##### NOTE

LPCMP may output a glitch and affect the value of CSR[CFF] and CSR[CFR] at the moment of enabling CMP. In order to ensure correctness, it is recommended to write one to clear (W1C) CSR[CFF] and CSR[CFR] before further configuring CMP.

##### Diagram

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24   | 23 | 22 | 21 | 20 | 19  | 18  | 17  | 16 |
|-------|----|----|----|----|----|----|----|------|----|----|----|----|-----|-----|-----|----|
| R     | 0  |    |    |    |    |    |    |      |    |    |    |    |     |     |     |    |
| W     |    |    |    |    |    |    |    |      |    |    |    |    |     |     |     |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0  | 0  | 0   | 0   | 0   | 0  |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8    | 7  | 6  | 5  | 4  | 3   | 2   | 1   | 0  |
| R     | 0  |    |    |    |    |    |    | COUT | 0  |    |    |    | RRF | CFF | CFR |    |
| W     |    |    |    |    |    |    |    |      |    |    |    |    | W1C | W1C | W1C |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0    | 0  | 0  | 0  | 0  | 0   | 0   | 0   | 0  |

**Fields**

| Field     | Function                                                                                                                                                                                                                                                                                                                                                  |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-9<br>— | Reserved                                                                                                                                                                                                                                                                                                                                                  |
| 8<br>COUT | Analog Comparator Output<br>Returns the current value of the analog comparator output when read. This field resets to 0 and reads as <a href="#">CCR1[COUT_INV]</a> after the analog comparator module disables when <a href="#">CCR0[CMP_EN]</a> = 0. Writing to this field is ignored.                                                                  |
| 7-3<br>—  | Reserved                                                                                                                                                                                                                                                                                                                                                  |
| 2<br>RRF  | Round-Robin Flag<br>Detects when any channel's last comparison result is different from the pre-set value in Trigger mode. Write 1 to clear this field. This field clears when <a href="#">CCR0[CMP_EN]</a> or <a href="#">RRCR0[RR_EN]</a> is not 1.<br>0b - Not detected<br>1b - Detected                                                               |
| 1<br>CFF  | Analog Comparator Flag Falling<br>Detects when a falling edge on COUT occurs. Write 1 to clear this field when <a href="#">CCR1[DMA_EN]</a> is disabled. If <a href="#">CCR1[DMA_EN]</a> is enabled, the flag automatically clears after DMA is done. This field clears when <a href="#">CCR0[CMP_EN]</a> is not 1.<br>0b - Not detected<br>1b - Detected |
| 0<br>CFR  | Analog Comparator Flag Rising<br>Detects when a rising edge on COUT occurs. Write 1 to clear this field when <a href="#">CCR1[DMA_EN]</a> is disabled. If <a href="#">CCR1[DMA_EN]</a> is enabled, the flag automatically clears after DMA is done. This field clears when <a href="#">CCR0[CMP_EN]</a> is not 1.<br>0b - Not detected<br>1b - Detected   |

**41.7.9 Round Robin Control Register 0 (RRCR0)****Offset**

| Register | Offset |
|----------|--------|
| RRCR0    | 24h    |

**Function**

Contains configuration options for the round-robin operation, such as enabling it and specifying the initialization delay.

**Diagram**

| Bits  | 31                  | 30 | 29         | 28 | 27            | 26 | 25      | 24 | 23 | 22 | 21            | 20 | 19 | 18 | 17         | 16    |
|-------|---------------------|----|------------|----|---------------|----|---------|----|----|----|---------------|----|----|----|------------|-------|
| R     | RR_SAMPLE_THRESHOLD |    |            |    | RR_SAMPLE_CNT |    |         |    | 0  |    | RR_INITMOD    |    |    |    |            |       |
| W     | 0                   | 0  | 0          | 0  | 0             | 0  | 0       | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0          | 0     |
| Reset | 0                   | 0  | 0          | 0  | 0             | 0  | 0       | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0          | 0     |
| Bits  | 15                  | 14 | 13         | 12 | 11            | 10 | 9       | 8  | 7  | 6  | 5             | 4  | 3  | 2  | 1          | 0     |
| R     | 0                   |    | RR_CLK_SEL |    | 0             |    | RR_NSAM |    | 0  |    | RR_EXTTRG_SEL |    |    |    | RR_TR_G... | RR_EN |
| W     |                     |    | 0          | 0  | 0             | 0  | 0       | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0          | 0     |
| Reset | 0                   | 0  | 0          | 0  | 0             | 0  | 0       | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0          | 0     |

**Fields**

| Field                        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-28<br>RR_SAMPLE_THRESHOLD | <p>Sample Time Threshold</p> <p>Specifies that for one channel, when (RR_SAMPLE_THRESHOLD+1) sample results are "1", the final result is "1"; otherwise the final result is "0".</p> <p><b>NOTE</b><br/>This field must not be larger than <a href="#">RRCR0[RR_SAMPLE_CNT]</a>.</p> <ul style="list-style-type: none"> <li>0000b - At least 1 sampled "1", the final result is "1"</li> <li>0001b - At least 2 sampled "1", the final result is "1"</li> <li>0010b - At least 3 sampled "1", the final result is "1"</li> <li>0011b - At least 4 sampled "1", the final result is "1"</li> <li>0100b - At least 5 sampled "1", the final result is "1"</li> <li>0101b - At least 6 sampled "1", the final result is "1"</li> <li>0110b - At least 7 sampled "1", the final result is "1"</li> <li>0111b - At least 8 sampled "1", the final result is "1"</li> <li>1000b - At least 9 sampled "1", the final result is "1"</li> <li>1001b - At least 10 sampled "1", the final result is "1"</li> <li>1010b - At least 11 sampled "1", the final result is "1"</li> <li>1011b - At least 12 sampled "1", the final result is "1"</li> <li>1100b - At least 13 sampled "1", the final result is "1"</li> <li>1101b - At least 14 sampled "1", the final result is "1"</li> <li>1110b - At least 15 sampled "1", the final result is "1"</li> <li>1111b - At least 16 sampled "1", the final result is "1"</li> </ul> |
| 27-24                        | <p>Number of Sample for One Channel</p> <p>Specifies the number of samples for one channel.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RR_SAMPLE_CNT | 0000b - 1 samples<br>0001b - 2 samples<br>0010b - 3 samples<br>0011b - 4 samples<br>0100b - 5 samples<br>0101b - 6 samples<br>0110b - 7 samples<br>0111b - 8 samples<br>1000b - 9 samples<br>1001b - 10 samples<br>1010b - 11 samples<br>1011b - 12 samples<br>1100b - 13 samples<br>1101b - 14 samples<br>1110b - 15 samples<br>1111b - 16 samples                                                                                                   |
| 23-22         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| —             |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 21-16         | Initialization Delay Modulus                                                                                                                                                                                                                                                                                                                                                                                                                          |
| RR_INITMOD    | Specifies the number of round-robin clock cycles that determines the comparator and DAC initialization delay specified in the chip datasheet. Calculate the initialization delay as RR_INITMOD * (round-robin clock period).<br><br>For example, if the initialization delay is 80us and the round-robin clock is 100kHz, program RR_INITMOD to be 80us/10us = 8.<br><br>00_0000b - 63 cycles (same as 111111b)<br>00_0001b-11_1111b - 1 to 63 cycles |
| 15-14         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| —             |                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 13-12         | Round Robin Clock Source Select                                                                                                                                                                                                                                                                                                                                                                                                                       |
| RR_CLK_SEL    | Selects which clock source is used for the Round Robin clock. See the chip-specific LPCMP information for more on the Round Robin clock source information.<br><br>00b - Select Round Robin clock Source 0<br>01b - Select Round Robin clock Source 1                                                                                                                                                                                                 |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                        |                    |                        |      |   |       |      |       |   |
|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------------|------------------------|------|---|-------|------|-------|---|
|                          | 10b - Select Round Robin clock Source 2<br>11b - Select Round Robin clock Source 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                        |                    |                        |      |   |       |      |       |   |
| 11-10<br>—               | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                        |                    |                        |      |   |       |      |       |   |
| 9-8<br>RR_NSAM           | <p>Number of Sample Clocks</p> <p>Specifies the number of the round-robin clock cycles to wait after scanning the active channel before sampling the channel's comparison result. After the next cycle of the round-robin clock, the sampling takes place RR_NSAM clocks later.</p> <ul style="list-style-type: none"> <li>00b - 0 clock</li> <li>01b - 1 clock</li> <li>10b - 2 clocks</li> <li>11b - 3 clocks</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                        |                    |                        |      |   |       |      |       |   |
| 7-6<br>—                 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                        |                    |                        |      |   |       |      |       |   |
| 5-2<br>RR_EXTTRG_S<br>EL | <p>External Trigger Source Select</p> <p>Selects the external trigger from 16 trigger sources. See the chip-specific LPCMP information for more on the trigger source information.</p> <p><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> <table border="1" data-bbox="334 1298 1455 1488"> <thead> <tr> <th>Instance</th><th>Field supported in</th><th>Field not supported in</th></tr> </thead> <tbody> <tr> <td>CMP0</td><td>—</td><td>RRCR0</td></tr> <tr> <td>CMP1</td><td>RRCR0</td><td>—</td></tr> </tbody> </table> <ul style="list-style-type: none"> <li>0000b - Select external trigger source 0</li> <li>0001b - Select external trigger source 1</li> <li>0010b - Select external trigger source 2</li> <li>0011b - Select external trigger source 3</li> <li>0100b - Select external trigger source 4</li> <li>0101b - Select external trigger source 5</li> <li>0110b - Select external trigger source 6</li> <li>0111b - Select external trigger source 7</li> </ul> | Instance               | Field supported in | Field not supported in | CMP0 | — | RRCR0 | CMP1 | RRCR0 | — |
| Instance                 | Field supported in                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Field not supported in |                    |                        |      |   |       |      |       |   |
| CMP0                     | —                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RRCR0                  |                    |                        |      |   |       |      |       |   |
| CMP1                     | RRCR0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | —                      |                    |                        |      |   |       |      |       |   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                           |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | 1000b - Select external trigger source 8<br>1001b - Select external trigger source 9<br>1010b - Select external trigger source 10<br>1011b - Select external trigger source 11<br>1100b - Select external trigger source 12<br>1101b - Select external trigger source 13<br>1110b - Select external trigger source 14<br>1111b - Select external trigger source 15 |
| 1<br>RR_TRG_SEL | <b>Round-Robin Trigger Select</b><br>Selects the internal trigger or external trigger as the trigger source.<br>0b - External trigger<br>1b - Internal trigger                                                                                                                                                                                                     |
| 0<br>RR_EN      | <b>Round-Robin Enable</b><br>Enables the round-robin operation.<br>0b - Disable<br>1b - Enable                                                                                                                                                                                                                                                                     |

#### 41.7.10 Round Robin Control Register 1 (RRCR1)

##### Offset

| Register | Offset |
|----------|--------|
| RRCR1    | 28h    |

##### Function

Contains configuration options for the round-robin operation, such as enabling individual channels to participate.

**Diagram**

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23           | 22           | 21           | 20           | 19           | 18           | 17           | 16           |
|-------|----|----|----|----|----|----|----|----|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
| R     | 0  |    |    |    |    |    |    |    | FIXCH        |              |              |              | 0            |              | FIXP         |              |
| W     |    |    |    |    |    |    |    |    |              |              |              |              |              |              |              |              |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7            | 6            | 5            | 4            | 3            | 2            | 1            | 0            |
| R     | 0  |    |    |    |    |    |    |    | RR_C<br>H7EN | RR_C<br>H6EN | RR_C<br>H5EN | RR_C<br>H4EN | RR_C<br>H3EN | RR_C<br>H2EN | RR_C<br>H1EN | RR_C<br>H0EN |
| W     |    |    |    |    |    |    |    |    | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0            | 0            | 0            | 0            | 0            | 0            | 0            | 0            |

**Fields**

| Field          | Function                                                                                                                                                                                                                                                                                       |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-23<br>—     | Reserved                                                                                                                                                                                                                                                                                       |
| 22-20<br>FIXCH | Fixed Channel Select<br><br>Selects which channel in the mux port to fix for a given round-robin trigger mode application.<br><br>000b - Channel 0<br>001b - Channel 1<br>010b - Channel 2<br>011b - Channel 3<br>100b - Channel 4<br>101b - Channel 5<br>110b - Channel 6<br>111b - Channel 7 |
| 19-17<br>—     | Reserved                                                                                                                                                                                                                                                                                       |
| 16<br>FIXP     | Fixed Port<br><br>Fixes an analog mux port (plus or minus) for round-robin trigger mode. The inputs to the non-fixed port sweep during each round.<br><br>0b - Fix the plus port. Sweep only the inputs to the minus port.<br>1b - Fix the minus port. Sweep only the inputs to the plus port. |
| 15-8<br>—      | Reserved                                                                                                                                                                                                                                                                                       |
| 7-0            | Channel n Input Enable in Trigger Mode                                                                                                                                                                                                                                                         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                    |
|----------|-----------------------------------------------------------------------------------------------------------------------------|
| RR_CHnEN | Enables channel n of the non-fixed mux port to check its voltage value when in Trigger mode.<br>0b - Disable<br>1b - Enable |

#### 41.7.11 Round Robin Control and Status (RRCSR)

##### Offset

| Register | Offset |
|----------|--------|
| RRCSR    | 2Ch    |

##### Function

Contains the latest comparison results of the individual channels with the fixed mux port. It also allows you to define the pre-set state for each channel.

##### Diagram

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23     | 22     | 21     | 20     | 19     | 18     | 17     | 16     |
|-------|----|----|----|----|----|----|----|----|--------|--------|--------|--------|--------|--------|--------|--------|
| R     |    |    |    |    |    |    |    |    | 0      |        |        |        |        |        |        |        |
| W     |    |    |    |    |    |    |    |    |        |        |        |        |        |        |        |        |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| R     |    |    |    |    | 0  |    |    |    | RR_C   |
| W     |    |    |    |    |    |    |    |    | H7O... | H6O... | H5O... | H4O... | H3O... | H2O... | H1O... | H0O... |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

##### Fields

| Field            | Function                                                                                                                                                     |
|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8<br>—        | Reserved                                                                                                                                                     |
| 7-0<br>RR_CHnOUT | Comparison Result for Channel n<br>Returns the latest comparison result for channel n when read and defines the pre-set state for channel n when written to. |

### 41.7.12 Round Robin Status (RRSR)

#### Offset

| Register | Offset |
|----------|--------|
| RRSR     | 30h    |

#### Function

Contains individual channel flags that indicates when a channel's last comparison result is different from its pre-set value.

#### Diagram

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23          | 22          | 21          | 20          | 19          | 18          | 17          | 16          |
|-------|----|----|----|----|----|----|----|----|-------------|-------------|-------------|-------------|-------------|-------------|-------------|-------------|
| R     |    |    |    |    |    |    |    |    | 0           |             |             |             |             |             |             |             |
| W     |    |    |    |    |    |    |    |    |             |             |             |             |             |             |             |             |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7           | 6           | 5           | 4           | 3           | 2           | 1           | 0           |
| R     |    |    |    |    | 0  |    |    |    | RR_<br>CH7F | RR_<br>CH6F | RR_<br>CH5F | RR_<br>CH4F | RR_<br>CH3F | RR_<br>CH2F | RR_<br>CH1F | RR_<br>CH0F |
| W     |    |    |    |    |    |    |    |    | W1C         |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0           | 0           | 0           | 0           | 0           | 0           | 0           | 0           |

#### Fields

| Field          | Function                                                                                                                                                                                                                                     |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-8<br>—      | Reserved                                                                                                                                                                                                                                     |
| 7-0<br>RR_CHnF | Channel n Input Changed Flag<br>Indicates when the corresponding channel's last comparison result is different from its pre-set value.<br><br>———— NOTE ————<br>To clear a flag, write a 1 to it.<br><br>0b - No different<br>1b - Different |

### 41.7.13 Round Robin Control Register 2 (RRCR2)

#### Offset

| Register | Offset |
|----------|--------|
| RRCR2    | 38h    |

**Function**

Provides the controls for the round-robin internal trigger generation.

**Diagram**

| Bits  | 31    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23              | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-------|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|----|----|
| R     | RR_TI | 0  |    |    |    |    |    |    |                 |    |    |    |    |    |    |    |
| W     | ME... |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |    |
| Reset | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bits  | 15    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7               | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     |       |    |    |    |    |    |    |    | RR_TIMER_RELOAD |    |    |    |    |    |    |    |
| W     |       |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |    |
| Reset | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Fields**

| Field                   | Function                                                                                                                                                                                                                                                                                 |
|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>RR_TIMER_EN       | Round-Robin Internal Timer Enable<br><br>Enables round-robin internal timer.<br><br>0b - Disables<br>1b - Enables                                                                                                                                                                        |
| 30-28<br>—              | Reserved                                                                                                                                                                                                                                                                                 |
| 27-0<br>RR_TIMER_RELOAD | Number of Sample Clocks<br><br>Establishes the repetitive count rate for the round-robin internal timer. Each time the timer counts zero it is reloaded with this value. The round-robin trigger signal generates at a rate of (RR_TIMER_RELOAD + 1) times the round-robin clock period. |

# Chapter 42

## Debug

### 42.1 Introduction

Cortex-M33 debug functionality is based on ARM CoreSight debug infrastructure, and includes processor halt, single-step, processor core register access, Vector Catch, unlimited software breakpoints, and full system memory access. The processor also includes support for hardware breakpoints and watchpoints configured during implementation:

- A breakpoint unit supporting four instruction comparators.
- A watchpoint unit supporting two watchpoint comparators.

The Cortex-M33 processor supports system level debug authentication to control access from a debugger to resources and memory.

Features:

- The ARM CoreSight Architecture adapted for software trace and debug.
- Serial wire debug (SWD) and Debug Access Port (DAP) to support debugger tools.
- The following are supported for the Cortex-M33 subsystem:
  - Instrumentation Trace Macrocell (ITM)
  - Data Watchpoint and Trace (DWT)
  - Breakpoint Unit (BPU)
  - Software trace and full instruction trace
- SWO trace port for efficiently accessing CM33 trace information from the system

The following figures show the system level debug architecture.



Figure 195. Debug architecture

## 42.2 Debug/Trace component

### 42.2.1 D-AHB interface

The 32-bit Debug AHB (D-AHB) interface implements the AMBA 5 AHB protocol. It can be used with a CoreSight AHB-AP to provide debugger access to all processor control and debug resources, and a view of memory that is consistent with that observed by load/store instructions acting on the processor.

### 42.2.2 AHB-AP debug access port

The AHB-AP is an optional debug access port into the processor system that provides access to all memory and registers in the system, including processor registers through the SCS. System access is independent of the processor status. SWJ-DP is used to access the AHB-AP.

### 42.2.3 Data Watchpoint and Trace

A Reduced DWT contains two comparators (DWT\_COMP0 to DWT\_COMP1). These comparators support the following features:

- Hardware watchpoint support.
- Hardware trace packet support, only if it includes an ITM.
- Cycle counter matching support (DWT\_COMP0 only).
- Instruction address matching support.
- Data address matching support.
- Data value matching support (DWT\_COMP1 only).
- Linked/limit matching support (DWT\_COMP1 only).

The DWT contains counters for:

- Cycles (CYCCNT)
- Folded Instructions (FOLDCNT).
- Additional cycles required to execute all load or store instructions (LSUCNT).
- Processor sleep cycles (SLEEP\_CNT).
- Additional cycles required to execute multi-cycle instructions and instruction fetch stalls (CPICNT)
- Cycles spent in exception processing (EXCCNT).

The user can configure the DWT to generate PC samples at defined intervals, and to generate interrupt event information. The DWT provides periodic requests for protocol synchronization to the ITM and the TPIU.

### 42.2.4 In System Programming - Access Port (ISP-AP)

The ISP-AP provides a useful interface between debugger and the core and controls the debug information.

### 42.2.5 Cortex M33 debug

This section covers the debug mechanisms associated with the CM33 processor.

#### 42.2.5.1 CM33 software and hardware trace

Refer [Figure 195](#) to see data flow of software debug and trace information for the Cortex-M33 core on this device.

#### 42.2.5.2 Breakpoint Unit

The CM33 Breakpoint Unit (BPU) module comprises up to 8 instruction address comparators. It provides breakpoint functionality on all instructions fetched across the entire address range in which code can be located.

#### 42.2.5.3 Instrumentation Trace Macrocell (ITM)

The ITM generates trace information as packets. There are multiple sources that can generate packets. If multiple sources generate packets at the same time, the ITM arbitrates the order in which packets are output. The sources in decreasing order of priority are:

- Software Trace: Application software can write console messages directly to ITM stimulus ports, and output them to the host as trace packets.
- Hardware trace: The DWT generates these packets, and the ITM outputs them.
- Timestamping: ITM can generate timestamp packets that are inserted in to the trace stream, to help the host debugger to find out the timing of events. Timestamps are generated relative to packets. The ITM contains a 21-bit counter to generate the timestamp.
- Global timestamping: External timestamps can be generated from OS Timer.

Trace data from ITM will be forwarded to either the TPIO or the SWO-TPIU and streamed out via the trace port. Trace data from ITM can also be collected to the embedded trace buffer.

### 42.3 Test and debug port connectivity

The following figure shows the connectivity of test and debug port on this device.



Figure 196. Test and debug port connectivity

The JTAG and SWD signals are summarized in the following table.

Table 259. JTAG/SWD signals summary

| Pin Name              | JTAG |                | SWD  |             | Internal pull up/down |
|-----------------------|------|----------------|------|-------------|-----------------------|
|                       | Type | Description    | Type | Description |                       |
| TMS/SWDIO             | I    | Mode selection | I/O  | Data        | Pull-up               |
| TCLK/SWCLK/TRACECLKIN | I    | Clock          | I    | Clock       | Pull-down             |
| TDI                   | I    | Data input     | --   | --          | Pull-up               |
| TDO                   | O    | Data output    | --   | --          | N/A                   |

JTAG mode is the default connection of the JTAG/SWD port. The following sequence of events would switch the debug port to SWD mode.

JTAG-to-SWD change sequence has following steps:

- Send more than 50 TCLK cycles with TMS(SWDIO) = 1
- Send the 16-bit sequence on TMS(SWDIO) = 0111\_1001\_1110\_0111 (MSB transmitted first)
- Send more than 50 TCLK cycles with TMS(SWDIO) = 1

Following is the JTAG ID table for this device.

| JTAG ID | Version | Part number | Manufacture    | mandatory |
|---------|---------|-------------|----------------|-----------|
| Value   | 0000b   | TBD         | 000 0001 0101b | 1b        |

### 42.3.1 Joint Test Access Group (JTAG)

#### 42.3.1.1 JTAG instruction registers

The JTAG TEST TAP is connected in parallel with Arm DAP controller, that is, the JTAG-DP port of the DAP. The Instruction Register (IR) length is 4-bits. The JTACG IR codes overlay the DAP controller IR codes. JTACG uses twelve instructions and the DAP uses the remaining four instructions. The outputs of the TAPs (TDO) are multiplexed based on the IR code which is selected. This design is fully JTAG compliant and appears to the JTAG chain as a single TAP.

The following table gives the IR codes for the system JTAG controller.

Table 260. JTAG TEST TAP

| Code    | JTAG IR           |
|---------|-------------------|
| 4'b0000 | IR_EXTEST         |
| 4'b0001 | SAMPLE/PRELOAD    |
| 4'b0010 | IR_HIGHZ          |
| 4'b0011 | IR_CLAMP          |
| 4'b0100 | IR_IDCODE         |
| 4'b0101 | Reserved          |
| 4'b0110 | Reserved          |
| 4'b0111 | Reserved          |
| 4'b1000 | ARM-DAP IR_ABORT  |
| 4'b1001 | Reserved          |
| 4'b1010 | ARM-DAP IR_DPACC  |
| 4'b1011 | ARM-DAP IR_APACC  |
| 4'b1100 | Reserved          |
| 4'b1101 | Reserved          |
| 4'b1110 | ARM-DAP IR_DAP_ID |
| 4'b1111 | ARM-DAP BYPASS    |

### 42.3.2 Debug access port

Debug Access Port (DAP) is a standard ARM CoreSight component. The DAP provides multiple master driving ports, all accessible and controlled through a single external interface port to provide system-wide debug. The DAP Instruction Register codes are listed in the following table.

**Table 261. DAP IR Codes**

| Code    | DAP IR |
|---------|--------|
| 4'b1000 | ABORT  |
| 4'b1010 | DPACC  |
| 4'b1011 | APACC  |
| 4'b1110 | IDCODE |

The DAP offers AHB and APB master interfaces to access system buses. It also exports the internal DAP bus to allow to extend the access ports as per the system requirement. It offers JTAG AP to allow adding auxiliary JTAG TAPs. For more information on DAP or JTAG devices under JTAG AP, refer to ARM Debug Interface v5 Architecture specification on [arm.com](http://arm.com)

The AHB AP's AHB transfers are burst size of 1 only, no out of order transactions, and no multiple outstanding accesses. The APB AP is used to access debug components of the system trace like TPIU and ETB.

The exported DAP bus is used to host AHB AP (integrated as part of CM33 integrations) and the Miscellaneous Debug Module Access Port (MDM AP). The MDM-AP implement registers which are used for Test mode control on the device. The MDM-AP hosts system level JTAG status and control registers (refer to Debug Status and Control Registers) which can be used for cross triggering, synchronized debug, low power and other miscellaneous control and status. The selection of different access ports in the DAP is done based on the APSEL value set in the SELECT register of SWJ-DP.

The exported DAP bus is used to host AHB AP (integrated as part of CM33 integrations). The selection of different access ports in the DAP is done based on the APSEL value set in the SELECT register of SWJ-DP.

## 42.4 Debug ROM tables

The debug ROM tables hold information about different debug components and help identify them. In this chip, this table resides in the CM33 core and contains entries for CM33 debug components.

**Table 262. Debug ROM table**

| Processor |                    | Start address |
|-----------|--------------------|---------------|
| CPU ROM   |                    | 0xE00FE000    |
|           | CM33 processor ROM | 0xE00FF000    |
|           | TPIU               | 0xE0040000    |

## 42.5 Low power debug

Low power debug is controlled by DBGCTL[SOD] field in the CMC. When set, the debugger is disabled (debug power up acknowledge negates) when the CM33 sleeps and the device fully enters the low power mode. When clear, the clocks to the CM33 remain enabled when the CM33 sleeps and debug is attached (debug power up request is asserted) to maintain the debug connection, and the low power mode is not completely entered. Software can modify DBGCTL[SOD] before each low power entry. There are two modes supported:

- Clock gated mode
- Power gated mode

### 42.5.1 Clock gated modes

If the SWJDAP debug power up request is high, and CMC\_DBGCTL[SOD] is clear, when the system attempts to enter STOP mode, the DAP clock and the FCLK continue to run to support core register access and trace. In this case, the debug module will have access to core registers but not to modules which are clock gated.

## 42.6 Halting execution immediately following ROM execution

Traditionally, debug systems may set a vector catch at the reset vector to break code execution, but the chip ROM prevents this method. To allow the debug system to halt execution immediately after the ROM completes preparations following a debug session request, set a watchpoint on a read access to address 40091040h.

The debugger should use this reset sequence:

1. Set the data watchpoint to halt the core on a read of address location 40091040h.
2. If all data watchpoint comparators are occupied, back-up one of the watchpoint settings and replace it with the above watchpoint location.
3. Reset the core and peripherals by setting AIRCR[SYSRESETREQ].
4. Wait for 100 msec to allow ROM to re-enable debug access.
5. Verify that the core has halted at the watchpoint by checking the DHCSR register.
6. If DHCSR read times out or returns an error response, the ROM has entered an ISP command-handling loop due to an invalid image in boot media.
  - a. Execute start debug session sequence.
  - b. Wait for 10 msec.
  - c. Enable the Cortex-M33 AP.
  - d. Read DHCSR and issue HALT to Cortex-M33 AP.
7. Clear data watchpoint added in step 1. If watchpoint was set as described in step 2, then restore the watchpoint configuration.

# Chapter 43

## Debug Mailbox

### 43.1 Chip-specific DBG\_MAILBOX information

Table 263. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | DBG_MAILBOX    | <a href="#">DBG_MAILBOX</a>         |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 43.1.1 Module instances

This device has one instance of the Debug Mailbox module.

#### 43.1.2 DM-AP commands

See the [Table 104](#) in the BootROM chapter for DM-AP commands supported by this device. You can ignore the DM-AP commands table in this chapter.

### 43.2 Overview

This chapter outlines the debug capabilities implemented in this chip through DBGMB. Debugging uses the Arm Serial Wire Debug (SWD) interface. This chapter is for debug tool developers and assumes that you know the Arm SWD interface and CoreSight (TM) debug and trace technology.

DBGMB is accessible through two paths:

- By software running on chip using DBGMB register interface as the access method.
- By tools software running on a PC connected to a device over SWD pins. These tools access DBGMB using Arm Debug Interface (ADIv5) specification where the individual nodes or ports are called Access Port (AP). In this context, we are using the DBGMB AP (DM-AP).

#### 43.2.1 Block diagram

This figure shows top-level debug ports and connections in this device.



Figure 197. Serial Wire Debug (SWD) internal connections

For JTAG identifier details, check the SYSCON chapter.

### 43.2.2 Features

- Supports Arm SWD mode.
- Includes Cortex-M33 CPU instruction trace capability via trace port, and output via a Serial Wire Viewer.
- Provides direct debug access to all memories, registers, and peripherals.
- No target resources required for debugging session.
- Can set instruction breakpoints.
- Can set data watchpoints, which can be used as triggers.
- Instrumentation Trace Macrocell (ITM) allows additional software-controlled trace for the CPU.

## 43.3 Functional description

### 43.3.1 Basic configuration

This device supports Arm's Serial wire Debug (SWD) interface. SWD is the default function for pins PIO0\_1 (SWCLK) and PIO0\_0 (SWDIO) after a reset. If Serial Wire Output (SWO) is to be used, it must be enabled in the application code by selecting the SWO function on either PIO0\_2 or PIO0\_6 and enabling the trace clock (see [External signals](#)).

Debug access via remote host is controlled by the ROM and is only enabled when permitted through the device configuration and when the correct protocol is followed to initiate a debug session. If the device has been configured for debug authentication, then a debug session must be initiated following the correct authentication sequence. When a device is in the development life-cycle state, the debug session protocol described in [Debug session protocol](#) should be used.

### 43.3.2 Debug Access Port (DAP)

The DAP with a Serial Wire Port (SWJ-DP) interprets incoming data and routes it to the appropriate Access Port (AP). External I/O pins that interface with DAP are described in [External signals](#). The DAP block is always enabled but the I/O pins that provide access to the SWD signals may be used for other functions controlled by <https://nxp.acrolinx.cloud/> software.

### 43.3.3 Arm Cortex-M33 Access Port

The Debug Access Port (DAP) for the Arm Cortex-M33 processor is disabled during power-on-reset or during the assertion of the reset pin. The DAP is enabled by the ROM when the correct debug initiation procedures are followed. If DAP is not being used, the debug enablement protocol can be used to initiate a debug session. The debug authentication process allows control of the DBGEN, NIDEN, SPIDEN and SPNIDEN authentication signals connected to Cortex-M33 as described below.

These signals are controlled by lifecycle/RoP state management, See Lifecycle/RoP chapter.

- **DBGEN:** Invasive debugging
  - Breakpoints and watch points halt the processor on a specific activity.
  - A debug connection examines and modifies registers and memory, and it provides single-step execution.
- **NIDEN:** Noninvasive debugging
  - Collects information on instruction execution and data transfers.
  - Delivers trace to off-chip in real time to tools to merge data with source code on a development workstation for future analysis.

### 43.3.4 Debugger Mailbox Access Port (DM-AP)

The Debugger Mailbox Access Port (DM-AP) offers a register-based mailbox accessible by CPU0 and the device debug port (DP) of the MCU. This port is always enabled and an external host communicating through the SWD interface can exchange messages and data with the boot code executing from ROM on CPU0. This port is used to implement the NXP Debug Authentication Protocol.

The boot ROM implements debug mailbox protocol to interact with tools via the SWD interface.

The protocol has following features:

- Based on requests and responses, where requests and responses use the same basic structure.
- Supports relatively large command and response data.
- All commands and responses are 32-bit word aligned.
- Supports data above 32-bits by using an ACK\_TOKEN that moderates the transfer in 32-bit value chunks.

### 43.3.5 Debug session protocol

When instructions are fetched from the ROM address range during boot, the DAP of CPU0 is disabled, regardless of device life-cycle state settings. This mechanism is referred as Boot-ROM protection in this document. The method to initiate a debug session varies depending on the device state and intended debug scenario. The scenarios described in the rest of these sections are:

- [Debug session with uninitialized/invalid image or ISP mode](#). If no valid image is detected, the ROM proceeds into In-System Programming (ISP) mode and waits to be booted via one of its serial interfaces. In ISP mode, the debug interface is disabled.
- [Debug session with valid application](#). Program control is in ISP mode, initiated because the ISP pin was asserted on the device at reset.
- [Debug session attaching to a running target](#). Connecting to a device running a valid application with the intent to debug without writing an image (also called a "debug attach").
- [Halting execution immediately following ROM execution](#). Connecting to a device running a valid application, with the intent to write a new application.

#### 43.3.5.1 Debug session with uninitialized/invalid image or ISP mode

When the device boots, there might not be a valid image in the boot media. In this case, the ROM-based program control enters In-System Programming (ISP) mode, and debug access is disabled for security reasons. The device might also be placed into ISP mode because the ISP has been asserted as the device leaves reset. This section describes how to establish a debug session for these scenarios.

To ensure that the state machine controlling debug mailbox commands is in a known state, the debugger can reset this logic. This reset is done by setting CSW[RESYNCH\_REQ] to 1. The debugger must then reset the device by writing a 1 to CSW[CHIP\_RESET\_REQ]. After requesting resynchronization and resetting the device, the debugger reads the CSW register. The debugger must wait until the device has completed resynchronization, by reading a value of 0 from the lower 16 bits of the CSW register.

To start a debug session and control the exchange of debug information, use the DM-AP commands. Following a successful initial resynchronization, the debugger communicates with the device via 32-bit [DM-AP commands](#) to the REQUEST register in the Debug Mailbox. The debugger can read results via the RETURN register. The debugger should poll the RETURN register as it polled the CSW register following a resynchronization request, to ensure that transactions have completed successfully. Results are shown in [Response Packet](#).

To initiate a debug session over SWD while debug is disabled, the debug system must issue a Start Debug Session command to the ROM-based boot code. This command must follow debug mailbox protocol. Upon receiving the command, the boot code disables any unwanted peripheral and manages secrets before enabling debug access. After enabling debug access, the ROM enters a while (1) loop.

Once the Start Debug Session command and device reset have executed successfully, the AP for CPU0 is accessible. It can be used to set breakpoints and perform other tasks, as with other Arm Cortex-M devices.

The code sample below shows how a debug session is initiated for the scenarios described above:

```
// Pseudo Code Syntax
// -----
// WriteDP "register" "value"
// value = ReadDP "register"
```

```

// AP transactions presume the DM AP is selected
// WriteAP "register" "value"
// value = ReadAP "register" "value"
// -----
// Read AP ID register to identify DM AP at index 1
WriteDP 1 0x020000F0
// The returned AP ID should be 0x002A0000
value = ReadAP 3
print "AP ID: ", value

// Select DM AP index 1
WriteDP 1 0x02000000
// Write DM RESYNC_REQ + CHIP_RESET_REQ
WriteAP 0 0x21
// Poll CSW register (0) for zero return, indicating success
value = -1
while value != 0 {
    value = ReadAP 0
}
print "RESYNC_REQ + CHIP_RESET_REQ: ", value
// Write DM START_DBG_SESSION to REQUEST register (1)
WriteAP 1 7
// Poll RETURN register (2) for zero return
value = -1
while value != 0 {
    value = (ReadAP 2 & 0xFFFF)
}
print "DEBUG_SESSION_REQ: ", value

```

Following a successful debug connection, a flashloader is loaded into RAM to program the application to be debugged and to set required breakpoints in the code. After this process, a SYSRESET\_REQ command should be issued, verifying that the ROM fully executes (as a deployed end application would) before reaching the downloaded application.

#### 43.3.5.2 Debug session with valid application

In this case, it is assumed that debug has not been disabled by the application. The CPU0 AP is accessible and breakpoints can be set without resynchronizing the Mailbox hardware or issuing a Debug Session Request. The methods described in [Debug session with uninitialized/invalid image or ISP mode](#) may be used to simplify debug support implementations.

#### 43.3.5.3 Debug session attaching to a running target

In this scenario, the device has booted and is running an application that has not disabled debug. The host system is attempting to connect to the device without resetting it and without updating the application. In this case, the CPU0 AP should be accessible and breakpoints can be set without the need to resynchronize the Mailbox hardware.

#### 43.3.5.4 Halting execution immediately following ROM execution

Traditionally, debug systems may set a vector catch at the reset vector to break code execution, but the chip ROM prevents this method. To allow the debug system to halt execution immediately after the ROM completes preparations following a debug session request, set a watchpoint on a read access to address 0x40091040.

The debugger should use this reset sequence:

1. Set the data watchpoint to halt the core on a read of address location 0x40091040.
2. If all data watchpoint comparators are occupied, back-up one of the watchpoint settings and replace it with the above watchpoint location.

3. Reset the core and peripherals by setting AIRCR[SYSRESETREQ].
4. Wait for 100 msec to allow ROM to re-enable debug access.
5. Verify that the core has halted at the watchpoint by checking the DHCSR register.
6. If DHCSR read times out or returns an error response, the ROM has entered an ISP command-handling loop due to an invalid image in boot media.
  - a. Execute start debug session sequence described in [Debug session with uninitialized/invalid image or ISP mode](#).
  - b. Wait for 10 msec.
  - c. Enable the Cortex-M33 AP.
  - d. Read DHCSR and issue HALT to Cortex-M33 AP.
7. Clear data watchpoint added in step 1. If watchpoint was set as described in step 2, then restore the watchpoint configuration.

### 43.3.6 Reset handling

The debug domain (DP, Cortex-M33 AP, DM-AP) is reset upon Power On Reset (POR) or pin reset (assertion of external nRESET). On other resets, the debug domain retains its state. The defined breakpoints and watchpoints persist even when the debugging tool issues a reset to the device.

### 43.3.7 Mailbox commands

This section describes the Request and Response message formats and available mailbox commands.

#### 43.3.7.1 Request packet layout

The first word transmitted in a request is a header word containing the command ID and the number of following data words. The command packet is sent to the device by writing 32 bits at a time to the REQUEST register. When sending command packets greater than 32 bits, the debugger should read an ACK\_TOKEN in the RETURN register before writing the next 32 bits.

The 32-bit words quantified by the header follow the header itself.

Table 264. Request register byte description

| Word | Byte 0         | Byte 1          | Byte 2             | Byte 3              |
|------|----------------|-----------------|--------------------|---------------------|
| 0    | commandID[7:0] | commandID[15:8] | dataWordCount[7:0] | dataWordCount[15:8] |
| 1    | <i>data</i>    |                 |                    |                     |

The C structure definition for a request is:

```
struct dm_request {
    uint16_t commandID;
    uint16_t dataWordCount;
    uint32_t data[ ];
};
```

#### 43.3.7.1.1 DM-AP commands

DM-AP commands are written to the REQUEST register. An Exit DM\_AP command follows one or more of the DM-AP commands in the table below to resume the normal device boot flow. This sequence does not occur after the Enter ISP mode and Start Debug Session commands.

Table 265. DM-AP commands

| Name                            | Command code | Parameter/ Response                                                                                                                                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------------------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Start DM-AP<br>(legacy command) | 01h          | Parameters: None<br>Response: 32-bit status                                                                                                                             | Causes the device to enter DM-AP command mode. Must be done prior to sending other commands.<br><br>This command is provided for backward compatibility and does not need to be used.                                                                                                                                                                                                                                                                                                          |
| Get CRP Level                   | 02h          | Parameters: None<br>Response: 32-bit status                                                                                                                             | Returns CRP levels<br><br>Returns the device life cycle state using following mapping: <ul style="list-style-type: none"> <li>• 0 - In "Develop" life cycle state.</li> <li>• 1 - In "Develop2" life cycle state.</li> <li>• 2 - In "In-field" life cycle state.</li> <li>• 3 - In "Field Return OEM" life cycle state.</li> </ul>                                                                                                                                                             |
| Mass Erase<br>(legacy command)  | 03h          | Parameters: None<br>Response: 32-bit status                                                                                                                             | Erase the entire on-chip flash memory, excluding Protected Flash Regions (PFR)<br><br>This command erases the entire user flash memory. In addition, if the life cycle state value in OTP fuses is set to "Develop" (3h), then both CMPA and CFPA regions are erased.<br><br><b>NOTE</b><br>If the CFPA_LC_STATE is being used to test deployed life cycle states without programming fuses, then the CFPA_LC_STATE needs to be changed back to 0x0 or 0x3 in order to perform the mass erase. |
| Exit DM_AP<br>(legacy command)  | 04h          | Parameters: None<br>Response: 32-bit status                                                                                                                             | Causes the device to continue normal debug flow.                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Enter ISP Mode                  | 05h          | Parameters:<br>dataWordCount: 1h<br>data[0]: ISP mode enum.<br>FFFFFFFFFFh - Auto detection<br>See Boot ROM chapter for supported ISP modes.<br>Response: 32-bit status | Enter specified ISP mode.<br><br>By default, ISP mode entry is determined by the state of the ISP boot selection pins at reset time. Usually this functionality is disabled through PFR configuration prior to field deployment. This command can be used to enter ISP mode in those situations or when ISP boot selection pins are used for some other board function.                                                                                                                        |

*Table continues on the next page...*

Table 265. DM-AP commands (continued)

| Name              | Command code | Parameter/ Response                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------------|--------------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Set FA Mode       | 06h          | Parameters: None<br>Response: 32-bit status | This command sets the part permanently in Fault Analysis (FA) mode to return to NXP factory.<br><br>Upon receiving this command boot code in ROM, customer-sensitive assets (key codes) stored in PFR are erased. Also, the FA or RMA mode bit in the PFR field is set so suspect parts can be sent to NXP for FA/RMA testing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Start DBG Session | 07h          | Parameters: None<br>Response: 32-bit status | Start Debug Session<br><br>Program control is in ROM memory context when instructions are fetched from a ROM memory address range. When program control is in ROM memory context during boot, the debug access is disabled regardless of the device life-cycle state or DCFG_SOCU settings.<br><br>This command instructs the boot code in ROM to clean up memory and peripherals initialized by boot code: SysTick, UART, SPI, I2C, QSPI, SD/MMC, USB, MPU, and SAU. It also instructs the boot code to enter safe processor execution context for external debuggers to attach.<br><br>When no valid image is in boot media, the program control enters ISP command handler loop (still in ROM memory context) and debug access is disabled. As a result, an external debug system must use this command to indicate to the ROM its intention of connecting to the debugger.<br><br>Upon receiving the command, the ROM cleans all peripheral configurations and secrets before enabling debug access. After enabling debug access, the ROM enters a while(1) loop. |

### 43.3.7.2 Response packet layout

The first word transmitted in a response is a header word containing the command status and number of following data words. The command response can be read 32 bits at a time through the RETURN register. The initial 32 bits contains the response header as shown in the table below. When reading a response longer than 32 bits, the debugger should write the ACK\_TOKEN to the REQUEST register after every read until the full response packet is received.

**NOTE**

To support legacy LPC command and response values, Bit\_31 in the header indicates that the response follows new protocol structure. This bit is set when the new protocol is used.

Table 266. Response register byte description

| Word | Byte 0                       | Byte 1                        | Byte 2                       | Byte 3                                                    |
|------|------------------------------|-------------------------------|------------------------------|-----------------------------------------------------------|
| 0    | bits[7:0]:commandStatus[7:0] | bits[7:0]:commandStatus[15:8] | bits[7:0]:dataWordCount[7:0] | bits[6:0]:dataWordCount[14:8]<br>bits[7]:new_protocol[15] |
| 1    | <i>data</i>                  |                               |                              |                                                           |

The C structure definition for a response is:

```
struct dm_response {
    uint16_t commandStatus;
    uint16_t dataWordCount;
    uint32_t data[];
};
```

#### 43.3.7.2.1 Response Packet

The command response can be read 32 bits at a time through the RETURN register. The initial 32 bits contain the response header as shown in the table below. When reading a response greater than 32 bits, the debugger writes the ACK\_TOKEN to the REQUEST register after every read of the RETURN register until the full response packet is received.

Table 267. Response Packet

| Field                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>LONG_RESP         | Long response packet indicator. Also called new protocol indicator.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| [30:16]<br>REMAIN_TRANS | Number of times debugger should read RETURN register to receive remaining response data. The debugger writes ACK_TOKEN to the REQUEST register after every read of the RETURN register until the full response packet is received.<br><br><b>NOTE</b><br>REMAIN_TRANS is valid only when ERROR_SRESP is set to zero and LONG_RESP bit is set to one.                                                                                                                                                                                                                |
| [15:0]<br>ERROR_SRESP   | Short response data or error code<br><br>If bit_20 is not set then this field is interpreted as short response data. For example, the CRP level is returned in this field for GET_CRP_LEVEL command.<br><br>Error codes <ul style="list-style-type: none"> <li>• 0000h: Command succeeded.</li> <li>• 0001h: Debug mode not entered. This is returned if other commands are sent prior to the "Enter DM-AP" command.</li> <li>• 0002h: Command is not supported.</li> <li>• 0003h: Communication failure. ACK_TOKEN is missing during data transactions.</li> </ul> |

### 43.3.7.3 ACK\_TOKEN

The ACK\_TOKEN provides an acknowledgment to the sender during debug mailbox data transactions. The acknowledgment is used in the following ways:

- When the debugger issues a command with parameter data, it waits for ACK\_TOKEN (read through RETURN register) before writing the next 32-bit value to the REQUEST register.
- When the debugger receives a long response packet, it writes ACK\_TOKEN to the REQUEST register before reading the next 32-bit value from RETURN register.

Table 268. ACK\_TOKEN

| Field                   | Description                                         |
|-------------------------|-----------------------------------------------------|
| [31:16]<br>REMAIN_TRANS | Number of remaining data transactions.              |
| [15:0]<br>ACK_MARKER    | Acknowledgment marker. Must always be set to A5A5h. |

The C structure definition for a ACK\_TOKEN is:

```
struct dm_ack_token {
    uint16_t token; /* always set to A5A5h */
    uint16_t remainCount; /* count of remaining word */
};
```

### 43.3.7.4 Error handling

When an overrun occurs from either side of the communication, the appropriate error flag is set in the CSW register. The state machine hardware prevents further communication in either direction. The debugger must start with a new resynchronization request to clear the error flag.

### 43.3.8 Fault Analysis (FA) mode

The ROM on this device has an FA mode command (SET\_FA\_MODE) to enable deletion of sensitive information (for example, keys) before giving the device to NXP for fault analysis. The ROM allows the SET\_FA\_MODE command only when a corresponding flag in Debug\_State is set.

## 43.4 External signals

Table 269 shows the signals related to the debug process. A trace using the Serial Wire Output has limited bandwidth.

Table 269. Serial wire debug signals

| Signal | I/O | Description                                                                                                                                                                                                                 |
|--------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SWCLK  | In  | <b>Serial Wire Clock.</b> Provides the clock for the SWD debug logic when in Serial Wire Debug mode (SWD). SWCLK is the default signal of its pin. At the release of reset, the pin is pulled down internally.              |
| SWDIO  | I/O | <b>Serial Wire Debug Data input/output.</b> Used by an external debug tool to communicate with and control the part. SWDIO is the default signal of its pin. At the release of reset, the pin is pulled up internally.      |
| SWO    | Out | <b>Serial Wire Output.</b> Optionally provides data from the Instrumentation Trace Macrocell (ITM) for an external debug tool to evaluate. See the chip-specific DBGMB information for the clocking required to enable SWO. |

## 43.5 Memory map and register definition

### 43.5.1 DBGMB register descriptions

#### 43.5.1.1 DBGMB memory map

DebugMailbox0 base address: 4010\_1000h

| Offset | Register                      | Width<br>(In bits) | Access | Reset value |
|--------|-------------------------------|--------------------|--------|-------------|
| 0h     | Command and Status Word (CSW) | 32                 | RW     | 0000_0000h  |
| 4h     | Request Value (REQUEST)       | 32                 | RW     | 0000_0000h  |
| 8h     | Return Value (RETURN)         | 32                 | RW     | 0000_0000h  |
| FCh    | Identification (ID)           | 32                 | R      | 002A_0000h  |

#### 43.5.1.2 Command and Status Word (CSW)

##### Offset

| Register | Offset |
|----------|--------|
| CSW      | 0h     |

##### Function

Contains command and status bits to facilitate communication between DBGMB and the device.

##### Diagram



##### Fields

| Field | Function |
|-------|----------|
| 31-6  | Reserved |

Table continues on the next page...

*Table continued from the previous page...*

| Field               | Function                                                                                                                                                                                                                                                    |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| —                   |                                                                                                                                                                                                                                                             |
| 5<br>CHIP_RESET_REQ | Chip Reset Request<br>This write-only bit causes the device (but not the DM-AP) to be reset by generating SYSRESET_REQ.                                                                                                                                     |
| 4<br>SOFT_RESET     | Soft Reset<br>The SOFT_RESET bit is write only by the device and resets the DM-AP.                                                                                                                                                                          |
| 3<br>AHB_OR_ERR     | AHB Overrun Error<br>Indicates whether an AHB overrun has occurred: a RETURN value has been overwritten by the device before the RETURN value was read by DBGMB.<br>0b - No AHB Overrun Error<br>1b - AHB Overrun Error. An AHB overrun occurred.           |
| 2<br>DBG_OR_ERR     | DBGMB Overrun Error<br>Indicates whether a DBGMB overrun has occurred: a REQUEST value has been overwritten by DBGMB before the REQUEST value was read by the device.<br>0b - No DBGMB Overrun error<br>1b - DBGMB overrun error. A DBGMB overrun occurred. |
| 1<br>REQ_PENDING    | Request Pending<br>A request is pending for DBGMB: a value is waiting to be read from the REQUEST register.<br>0b - No request pending<br>1b - Request for resynchronization pending                                                                        |
| 0<br>RESYNCH_REQ    | Resynchronization Request<br>Sets RESYNCH_REQ to request a resynchronization.<br>0b - No request<br>1b - Request for resynchronization                                                                                                                      |

#### 43.5.1.3 Request Value (REQUEST)

##### Offset

| Register | Offset |
|----------|--------|
| REQUEST  | 4h     |

##### Function

Used by DBGMB to send action requests to the device.

**Diagram**

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

**Fields**

| Field   | Function                                                                                                              |
|---------|-----------------------------------------------------------------------------------------------------------------------|
| 31-0    | Request Value                                                                                                         |
| REQUEST | Reads as 0 when no new request is present. Cleared by the device. Can be read back by DBGMB to confirm communication. |

**43.5.1.4 Return Value (RETURN)****Offset**

| Register | Offset |
|----------|--------|
| RETURN   | 8h     |

**Function**

Provides the responses from the device to DBGMB.

**Diagram**

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

## Fields

| Field | Function                                                                                                                           |
|-------|------------------------------------------------------------------------------------------------------------------------------------|
| 31-0  | Return Value                                                                                                                       |
| RET   | This value is any response from the device to DBGMB. If no new data is present, DBGMB read is stalled until new data is available. |

### 43.5.1.5 Identification (ID)

#### Offset

| Register | Offset |
|----------|--------|
| ID       | FCh    |

#### Function

The ID register provides an identification of the DM-AP interface.

#### Diagram



#### Fields

| Field | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-0  | Identification Value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| ID    | The ID register provides an identification of the DM-AP interface. The ARM Debug Interface Specification version 5.0 (ADIV5) requires every AP to implement an AP Identification Register, at offset FCh. ID is the last register in the AP register space. This ID register is only readable from external tools (a debug dongle) when identifying the Access Port (AP). For the debug mailbox AP the identification value is 002A_0000h. This register is not readable from on-chip software. If you attempt a read, you receive a value of 0000_0000h. |

# Chapter 44

## Cyclic Redundancy Check (CRC)

### 44.1 Chip-specific CRC information

Table 270. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | CRC            | <a href="#">CRC</a>                 |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 44.1.1 Module instances

This device has one instance of the CRC module, CRC0.

### 44.2 Overview

CRC generates 16-bit or 32-bit CRC codes output for error detection. You can calculate these codes for up to 32 bits input data at a time.

CRC provides a programmable polynomial and other parameters to meet 16-bit or 32-bit CRC standards.

#### 44.2.1 Block diagram



Figure 198. Block diagram

#### 44.2.2 Features

CRC has the following features:

- Hardware CRC generator circuit using 16-bit or 32-bit programmable shift registers

- Programmable initial seed value and polynomial
- Transpose of input or output data (CRC result) in bitwise or bytewise (this option is required for certain CRC standards. You cannot perform a bytewise transpose operation when accessing [DATA](#) via 8-bit access.)
- Invert final CRC result
- 32-bit CPU register programming interface

## 44.3 Functional description

### 44.3.1 Modes of operation

The following sections describe various modes of operation that affect the functionality of CRC: [Run mode](#) and [Low power mode](#).

#### 44.3.1.1 Run mode

Run mode is the basic mode of operation.

#### 44.3.1.2 Low power mode

When the chip enters the lower power mode, the CRC module clock ([ipg\\_clk](#) and [ipg\\_clk\\_s](#)) is disabled and the in-progress CRC calculation stops. The calculation resumes after the CRC module clock is enabled or the chip exits low power mode via system reset.

### 44.3.2 CRC calculations

In 16-bit and 32-bit CRC modes, you can program data values as 8 bits, 16 bits, or 32 bits at a time, provided all bytes are contiguous. Noncontiguous bytes lead to an incorrect CRC calculation.

#### 44.3.2.1 Calculating a 16-bit CRC

Perform these steps to calculate a 16-bit CRC:

1. Write 0 to [CTRL\[TCRC\]](#) to enable 16-bit CRC mode.
2. Program the transpose and complement options in [Data \(DATA\)](#) as required for the CRC calculation.
3. Write a 16-bit polynomial to [GPOLY\[LOW\]](#).  
[GPOLY\[HIGH\]](#) is not usable in 16-bit CRC mode.
4. Write 1 to [CTRL\[WAS\]](#) to program the seed value.
5. Write a 16-bit seed to [DATA\[LU\]](#) and [DATA\[LL\]](#).  
[DATA\[HU\]](#) and [DATA\[HL\]](#) are not used.
6. Write 0 to [CTRL\[WAS\]](#) to start writing data values.
7. Write data values into [DATA\[LU\]](#), and [DATA\[LL\]](#)

CRC is calculated on every data value write and the intermediate CRC result is stored back into [DATA\[LU\]](#) and [DATA\[LL\]](#)

8. After writing all the data values, read the final CRC result from [DATA\[LU\]](#) and [DATA\[LL\]](#).

CRC is calculated bytewise and two clocks are required to complete one CRC calculation.

The transpose and complement operations are performed on-the-fly when reading or writing values. See [Transpose feature](#) and [Result complement](#) for details.

#### 44.3.2.2 Calculating a 32-bit CRC

Perform these steps to calculate a 32-bit CRC:

1. Write 1 to [CTRL\[TCRC\]](#) to enable 32-bit CRC mode.

2. Program the transpose and complement options in [Control \(CTRL\)](#) as required for CRC calculation. See [Transpose feature](#) and [Result complement](#) for details.
3. Write a 32-bit polynomial to [GPOLY\[HIGH\]](#) and [GPOLY\[LOW\]](#).
4. Write 1 to [CTRL\[WAS\]](#) to program the seed value.
5. Write a 32-bit seed to [DATA\[HU\]](#), [DATA\[HL\]](#), [DATA\[LU\]](#), and [DATA\[LL\]](#).
6. Write 0 to [CTRL\[WAS\]](#) to start writing data values.
7. Write data values into [DATA\[HU\]](#), [DATA\[HL\]](#), [DATA\[LU\]](#), and [DATA\[LL\]](#)

CRC is computed on every data value write and the intermediate CRC result is stored back into [DATA\[LU\]](#) and [DATA\[LL\]](#)

8. After writing all the values, read the final CRC result from [DATA\[HU\]](#), [DATA\[HL\]](#), [DATA\[LU\]](#), and [DATA\[LL\]](#).

CRC is calculated bytewise and two clocks are required to complete one CRC calculation.

The transpose and complement operations are performed on-the-fly when reading or writing values. See [Transpose feature](#) and [Result complement](#) for details.

#### 44.3.3 Transpose feature

Transpose is not enabled by default. However, CRC requires input data and/or final checksum to be transposed. You have an option to configure each transpose operation separately to meet CRC standards. The data is transposed on-the-fly while being read or written.

Some protocols use the little-endian format for data stream to calculateCRC. In this case, transpose flips bits.

##### 44.3.3.1 Types of transpose

CRC provides several types of transpose to flip bits and/or bytes for both writing input data and reading result separately using the [CTRL\[TOT\]](#) and [CTRL\[TOTR\]](#) according to the CRC calculation being used.

The following types of transpose are available for writing to and reading from [DATA](#).

1. [CTRL\[TOT\]](#) or [CTRL\[TOTR\]](#) is 0.

No transposition occurs.

2. [CTRL\[TOT\]](#) or [CTRL\[TOTR\]](#) is 1.

Bits in a byte are transposed when bytes are not transposed.

`reg[31:0]` becomes {`reg[24:31], reg[16:23], reg[8:15], reg[0:7]`}.



Figure 199. Transpose type 1b

3. [CTRL\[TOT\]](#) or [CTRL\[TOTR\]](#) is 10b.

Both bits in bytes and bytes are transposed.

`reg[31:0]` becomes {`reg[0:7], reg[8:15], reg[16:23], reg[24:31]`}.



Figure 200. Transpose type 10b

4. **CTRL[TOT]** or **CTRL[TOTR]** is 11b.

Bytes are transposed but bits are not transposed.

**reg[31:0]** becomes {**reg[7:0]**, **reg[15:8]**, **reg[23:16]**, **reg[31:24]**}.



Figure 201. Transpose type 11b

#### NOTE

For 8-bit and 16-bit write accesses to **Data (DATA)**, the data is transposed with 0s on the unused byte or bytes (taking 32 bits as a whole), but CRC is calculated on the valid byte(s) only. When reading the **Data (DATA)** for a 16-bit CRC result and using transpose options 10 and 11, the resulting value after transposition resides in **DATA[HU]** and **DATA[HL]**. You must account for this situation when reading the 16-bit CRC result, so reading 32 bits is preferred.

#### 44.3.4 Result complement

When **CTRL[FXOR] = 1**, the checksum is complemented. The CRC result complement function outputs the complement of the checksum value stored in **Data (DATA)** every time **Data (DATA)** is read. When **CTRL[FXOR] = 0**, reading **Data (DATA)** accesses the raw checksum value.

#### 44.3.5 Clocking

Table 271. CRC clocks

| Type of clock                    | Description                                                                                        |
|----------------------------------|----------------------------------------------------------------------------------------------------|
| Bus clock<br>(ipg_clk/ipg_clk_s) | ipg_clk_s controls the access to the CRC registers. ipg_clk and ipg_clk_s function the CRC module. |

#### 44.3.6 Interrupts

This module has no interrupts.

#### 44.4 External signals

There is no CRC signal that connects off chip.

#### 44.5 Initialization

To enable CRC calculation, you must program:

- **CTRL[WAS]** .
- **Polynomial (GPOLY)**.

- Parameters for transposition and CRC result inversion in the applicable registers.

Writing 1 to [CTRL\[WAS\]](#) enables you to program the seed value into CRC Data registers.

After writing all the data, you must wait for at least two clock cycles to read the data from CRC Data (DATA) register.

After a CRC calculation completes, you can reinitialize the module for a new CRC computation by again writing 1 to [CTRL\[WAS\]](#) and programming a new, or previously used, seed value. You must set all other parameters before programming the seed value and subsequent data values.

## 44.6 Use cases

The following tables use the little-endian format.

### 44.6.1 CTRL programming

The following table shows [Control \(CTRL\)](#) programming for 16-bit CRC.

Table 272. CTRL programming for 16-bit CRC

| Algorithm          | Polynomial | Seed  | Ref in | Ref out | XOR out | <a href="#">CTRL[TO T]</a> | <a href="#">CTRL[TO TR]</a> | <a href="#">CTRL[FX OR]</a> |
|--------------------|------------|-------|--------|---------|---------|----------------------------|-----------------------------|-----------------------------|
| CRC-16_CCITT_FALSE | 1021h      | FFFFh | 0      | 0       | 0000h   | 0h                         | 0h                          | 0h                          |
| CRC-16_ARC         | 8005h      | 0000h | 1      | 1       | 0000h   | 1h                         | 2h                          | 0h                          |
| CRC-16_AUG_CCITT   | 1021h      | 1D0Fh | 0      | 0       | 0000h   | 0h                         | 0h                          | 0h                          |
| CRC-16_BUYPASS     | 8005h      | 0000h | 0      | 0       | 0000h   | 0h                         | 0h                          | 0h                          |
| CRC-16_CCITT_ZERO  | 1021h      | 0000h | 0      | 0       | 0000h   | 0h                         | 0h                          | 0h                          |
| CRC-16_CDMA2000    | C867h      | FFFFh | 0      | 0       | 0000h   | 0h                         | 0h                          | 0h                          |
| CRC-16_DDS_110     | 8005h      | 800Dh | 0      | 0       | 0000h   | 0h                         | 0h                          | 0h                          |
| CRC-16_DECT_X      | 589h       | 0000h | 0      | 0       | 0000h   | 0h                         | 0h                          | 0h                          |
| CRC-16_DNP         | 3D65h      | 0000h | 1      | 1       | FFFFh   | 1h                         | 2h                          | 1h                          |
| CRC-16_EN_13757    | 3D65h      | 0000h | 0      | 0       | FFFFh   | 0h                         | 0h                          | 1h                          |
| CRC-16_GENIBUS     | 1021h      | FFFFh | 0      | 0       | FFFFh   | 0h                         | 0h                          | 1h                          |
| CRC-16_MAXIM       | 8005h      | 0000h | 1      | 1       | FFFFh   | 1h                         | 2h                          | 1h                          |
| CRC-16_MCRF4XX     | 1021h      | FFFFh | 1      | 1       | 0000h   | 1h                         | 2h                          | 0h                          |
| CRC-16_RIELLO      | 1021h      | B2AAh | 1      | 1       | 0000h   | 1h                         | 2h                          | 0h                          |
| CRC-16_T10_DIF     | 8BB7h      | 0000h | 0      | 0       | 0000h   | 0h                         | 0h                          | 0h                          |
| CRC-16_TELEDISK    | A097h      | 0000h | 0      | 0       | 0000h   | 0h                         | 0h                          | 0h                          |
| CRC-16_TMS37157    | 1021h      | 89ECh | 1      | 1       | 0000h   | 1h                         | 2h                          | 0h                          |
| CRC-16_USB         | 8005h      | FFFFh | 1      | 1       | FFFFh   | 1h                         | 2h                          | 1h                          |
| CRC-16_A           | 1021h      | C6C6h | 1      | 1       | 0000h   | 1h                         | 2h                          | 0h                          |
| CRC-16_KERMIT      | 1021h      | 0000h | 1      | 1       | 0000h   | 1h                         | 2h                          | 0h                          |
| CRC-16_MODBUS      | 8005h      | FFFFh | 1      | 1       | 0000h   | 1h                         | 2h                          | 0h                          |
| CRC-16_X_25        | 1021h      | FFFFh | 1      | 1       | FFFFh   | 1h                         | 2h                          | 1h                          |
| CRC-16_XMODEM      | 1021h      | 0000h | 0      | 0       | 0000h   | 0h                         | 0h                          | 0h                          |

The following table shows [Control \(CTRL\)](#) programming for 32-bit CRC.

**Table 273. CTRL programming for 32-bit CRC**

| Algorithm     | Polynomial | Seed      | Ref in | Ref out | XOR out    | CTRL[TOT] | CTRL[TO TR] | CTRL[FX OR] |
|---------------|------------|-----------|--------|---------|------------|-----------|-------------|-------------|
| CRC-32        | 04C11DB7h  | FFFFFFFFh | 1      | 1       | FFFF_FFFFh | 1h        | 2h          | 1h          |
| CRC-32_BZIP2  | 04C11DB7h  | FFFFFFFFh | 0      | 0       | FFFF_FFFFh | 0h        | 0h          | 1h          |
| CRC-32C       | 1EDC6F41h  | FFFFFFFFh | 1      | 1       | FFFF_FFFFh | 1h        | 2h          | 1h          |
| CRC-32D       | A833982Bh  | FFFFFFFFh | 1      | 1       | FFFF_FFFFh | 1h        | 2h          | 1h          |
| CRC-32_MPEG-2 | 04C11DB7h  | FFFFFFFFh | 0      | 0       | 0000_0000h | 0h        | 0h          | 0h          |
| CRC-32_POSIX  | 04C11DB7h  | 00000000h | 0      | 0       | FFFF_FFFFh | 0h        | 0h          | 1h          |
| CRC-32Q       | 814141ABh  | 00000000h | 0      | 0       | 0000_0000h | 0h        | 0h          | 0h          |
| CRC-32_JAMCRC | 04C11DB7h  | FFFFFFFFh | 1      | 1       | 0000_0000h | 1h        | 2h          | 0h          |
| CRC-32_XFER   | 000000AFh  | 00000000h | 0      | 0       | 0000_0000h | 0h        | 0h          | 0h          |

#### 44.6.2 Expected read data fields

The following table shows the expected read data fields for 16-bit CRC.

**Table 274. Expected read data fields for 16-bit CRC**

| Algorithm         | Data (DATA)                           |
|-------------------|---------------------------------------|
| CRC16_CCITT_FALSE | [31:16] = Unknown[15:0] = Valid data  |
| CRC16_ARC         | [31:16] = Valid data [15:0] = Unknown |
| CRC16_AUG_CCITT   | [31:16] = Unknown [15:0] = Valid data |
| CRC16_BUYPASS     | [31:16] = Unknown [15:0] = Valid data |
| CRC16_CCITT_ZERO  | [31:16] = Unknown [15:0] = Valid data |
| CRC16_CDMA2000    | [31:16] = Unknown [15:0] = Valid data |
| CRC16_DDS_110     | [31:16] = Unknown [15:0] = Valid data |
| CRC16_DECT_X      | [31:16] = Unknown [15:0] = Valid data |
| CRC16_DNP         | [31:16] = Valid data [15:0] = Unknown |
| CRC-16_EN_13757   | [31:16] = Unknown [15:0] = Valid data |
| CRC-16_GENIBUS    | [31:16] = Unknown [15:0] = Valid data |
| CRC-16_MAXIM      | [31:16] = Valid data [15:0] = Unknown |
| CRC-16_MCRF4XX    | [31:16] = Valid data [15:0] = Unknown |
| CRC-16_RIELLO     | [31:16] = Valid data [15:0] = Unknown |
| CRC-16_T10_DIF    | [31:16] = Unknown [15:0] = Valid data |
| CRC-16_TELEDISK   | [31:16] = Unknown [15:0] = Valid data |
| CRC-16_TMS37157   | [31:16] = Valid data [15:0] = Unknown |

*Table continues on the next page...*

**Table 274. Expected read data fields for 16-bit CRC (continued)**

| Algorithm     | Data (DATA)                           |
|---------------|---------------------------------------|
| CRC-16_USB    | [31:16] = Valid data [15:0] = Unknown |
| CRC-16_A      | [31:16] = Valid data [15:0] = Unknown |
| CRC-16_KERMIT | [31:16] = Valid data [15:0] = Unknown |
| CRC-16_MODBUS | [31:16] = Valid data [15:0] = Unknown |
| CRC-16_X_25   | [31:16] = Valid data [15:0] = Unknown |
| CRC-16_XMODEM | [31:16] = Unknown [15:0] = Valid data |

The following table shows the expected read data fields for 32-bit CRC.

**Table 275. Expected read data fields for 32-bit CRC**

| Algorithm     | Data (DATA)         |
|---------------|---------------------|
| CRC-32        | [31:0] = Valid data |
| CRC-32_BZIP2  | [31:0] = Valid data |
| CRC-32C       | [31:0] = Valid data |
| CRC-32D       | [31:0] = Valid data |
| CRC-32_MPEG-2 | [31:0] = Valid data |
| CRC-32_POSIX  | [31:0] = Valid data |
| CRC-32Q       | [31:0] = Valid data |
| CRC-32_JAMCRC | [31:0] = Valid data |
| CRC-32_XFER   | [31:0] = Valid data |

## 44.7 Memory map and register descriptions

### NOTE

You must reconfigure CRC engine in case an IPS transfer error occurs (ips\_xfr\_err).

The CRC module generates a transfer error in the following cases:

- Write accesses to the register addresses that are not mapped to the peripherals but included in the address spaces of the peripherals.

### 44.7.1 CRC register descriptions

#### 44.7.1.1 CRC memory map

CRC0 base address: 4008\_A000h

| Offset | Register    | Width<br>(In bits) | Access | Reset value |
|--------|-------------|--------------------|--------|-------------|
| 0h     | Data (DATA) | 32                 | RW     | FFFF_FFFFh  |

*Table continues on the next page...*

*Table continued from the previous page...*

| Offset | Register           | Width<br>(In bits) | Access | Reset value |
|--------|--------------------|--------------------|--------|-------------|
| 4h     | Polynomial (GPOLY) | 32                 | RW     | 0000_1021h  |
| 8h     | Control (CTRL)     | 32                 | RW     | 0000_0000h  |

#### 44.7.1.2 Data (DATA)

##### Offset

| Register | Offset |
|----------|--------|
| DATA     | 0h     |

##### Function

Configures the value of seed, data, and checksum. When CTRL[WAS] = 1, any write to this register is regarded as the seed value. When CTRL[WAS] becomes 0, any write to this register is regarded as data for general CRC calculation.

In 16-bit CRC mode, **DATA[HU]** and **DATA[HL]** are not used for programming the seed value, and reads of these fields return an indeterminate value. In 32-bit CRC mode, all fields are used for programming the seed value.

When programming data values, you can program to write 8 bits, 16 bits, or 32 bits in big endian order, provided all bytes are contiguous.

After writing all data values, you can read the CRC result from DATA register. In 16-bit CRC mode, the CRC result is available in **DATA[LU]** and **DATA[LL]**. In 32-bit CRC mode, all fields contain the result. After writing all data, you must wait for at least two clock cycles to read the data from CRC data (DATA) register.

##### Diagram



##### Fields

| Field | Function                |
|-------|-------------------------|
| 31-24 | Upper Part of High Byte |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field       | Function                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HU          | <p>Generates CRC checksum in both 16-bit and 32-bit CRC modes if CTRL[WAS] = 0.</p> <ul style="list-style-type: none"> <li>In 16-bit CRC mode (<a href="#">CTRL[TCRC] = 0</a>), this field is not used for programming a seed value.</li> <li>In 32-bit CRC mode (<a href="#">CTRL[TCRC] = 1</a>), the values written to this field are part of the seed value when <a href="#">CTRL[WAS] = 1</a>.</li> </ul> |
| 23-16<br>HL | <p>Lower Part of High Byte</p> <p>Generates CRC checksum in both 16-bit and 32-bit CRC modes if CTRL[WAS] = 1.</p> <ul style="list-style-type: none"> <li>In 16-bit CRC mode (CTRL[TCRC] = 0), this field is not used for programming a seed value.</li> <li>In 32-bit CRC mode (CTRL[TCRC] = 1), the values written to this field are part of the seed value when CTRL[WAS] = 1.</li> </ul>                  |
| 15-8<br>LU  | <p>Upper Part of Low Byte</p> <p>Generates CRC checksum when CTRL[WAS] = 0.</p> <p>When <a href="#">CTRL[WAS] = 1</a>, the values written to this field are part of the seed value.</p>                                                                                                                                                                                                                       |
| 7-0<br>LL   | <p>Lower Part of Low Byte</p> <p>Generates CRC checksum when CTRL[WAS] = 0.</p> <p>When CTRL[WAS] = 0, the values written to this field are part of the seed value.</p>                                                                                                                                                                                                                                       |

#### 44.7.1.3 Polynomial (GPOLY)

##### Offset

| Register | Offset |
|----------|--------|
| GPOLY    | 4h     |

##### Function

Configures polynomial value for CRC calculation.

- Sets the upper 16 bits of polynomial that are used only in 32-bit CRC mode. Writes to this field are ignored in 16-bit CRC mode.
- Sets the lower 16 bits of polynomial that are used in both 16-bit and 32-bit CRC modes.

**Diagram**

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

**Fields**

| Field | Function                                                                                                                       |
|-------|--------------------------------------------------------------------------------------------------------------------------------|
| 31-16 | High Half-Word                                                                                                                 |
| HIGH  | Writable and readable in 32-bit CRC mode (CTRL[TCRC] = 1). You cannot write to this field in 16-bit CRC mode (CTRL[TCRC] = 0). |
| 15-0  | Low Half-Word                                                                                                                  |
| LOW   | Writable and readable in both 16-bit and 32-bit CRC modes.                                                                     |

**44.7.1.4 Control (CTRL)****Offset**

| Register | Offset |
|----------|--------|
| CTRL     | 8h     |

**Function**

Sets control for CRC. You must write 1 to the appropriate fields of this register before starting a new CRC calculation, which you can initialize by writing 1 to CTRL[WAS] and then writing the seed into [DATA](#).

**Diagram**

| Bits  | 31  | 30 | 29   | 28 | 27 | 26   | 25  | 24   | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-----|----|------|----|----|------|-----|------|----|----|----|----|----|----|----|----|
| R     | TOT |    | TOTR |    | 0  | FXOR | WAS | TCRC | 0  |    |    |    |    |    |    |    |
| W     |     |    |      |    |    |      |     |      |    |    |    |    |    |    |    |    |
| Reset | 0   | 0  | 0    | 0  | 0  | 0    | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bits  | 15  | 14 | 13   | 12 | 11 | 10   | 9   | 8    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     | 0   |    |      |    |    |      |     |      |    |    |    |    |    |    |    |    |
| W     |     |    |      |    |    |      |     |      |    |    |    |    |    |    |    |    |
| Reset | 0   | 0  | 0    | 0  | 0  | 0    | 0   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

## Fields

| Field         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30<br>TOT  | <p>Transpose Type for Write</p> <p>Sets transpose type for the values written to <a href="#">DATA</a>. See <a href="#">Transpose feature</a> for the available transpose options.</p> <ul style="list-style-type: none"> <li>00b - No transposition</li> <li>01b - Bits in bytes are transposed, but bytes are not transposed.</li> <li>10b - Both bits in bytes and bytes are transposed.</li> <li>11b - Only bytes are transposed, no bits in a byte are transposed.</li> </ul> |
| 29-28<br>TOTR | <p>Transpose Type for Read</p> <p>Sets transpose type for the values read from <a href="#">DATA</a>. See <a href="#">Transpose feature</a> for the available transpose options.</p> <ul style="list-style-type: none"> <li>00b - No transposition</li> <li>01b - Bits in bytes are transposed, but bytes are not transposed.</li> <li>10b - Both bits in bytes and bytes are transposed.</li> <li>11b - Only bytes are transposed, no bits in a byte are transposed.</li> </ul>   |
| 27<br>—       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 26<br>FXOR    | <p>Complement Read of CRC Data Register</p> <p>Enables on-the-fly complementing of read data.</p> <p>Some CRC protocols require the final checksum to be XORed with FFFFFFFFh or FFFFh.</p> <ul style="list-style-type: none"> <li>0b - Disables XOR on reading data.</li> <li>1b - Inverts or complements the read value of the CRC Data.</li> </ul>                                                                                                                             |
| 25<br>WAS     | <p>Write as Seed</p> <p>Specifies whether writes to <a href="#">DATA</a> are data values or seed values.</p> <p>When this field = 1, the value that you write to is considered as seed value. When this field = 0, the value that you write to is considered as data for CRC calculation.</p> <ul style="list-style-type: none"> <li>0b - Data values</li> <li>1b - Seed values</li> </ul>                                                                                        |
| 24<br>TCRC    | <p>TCRC</p> <p>Defines the width of CRC.</p> <ul style="list-style-type: none"> <li>0b - 16 bits</li> <li>1b - 32 bits</li> </ul>                                                                                                                                                                                                                                                                                                                                                 |
| 23-0<br>—     | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

# Chapter 45

## Memory Block Checker(MBC)

### 45.1 Chip-specific MBC information

Table 276. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | MBC            | <a href="#">MBC</a>                 |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 45.1.1 Module instances

This device has one instance of the MBC module. The MBC is instanced between NPX and AHB Matrix. There is only one domain on this chip. MBC can control the Read, Write and Execute permission of each flash block, and the configuration can be locked. By default flash execute permission is disabled

#### 45.1.2 MBC memory blocks

The granularity of MBC is described in the following table.

| MBC0_MEMn | Memory     | Block size |
|-----------|------------|------------|
| MEM0      | Main flash | 8 KB       |
| MEM1      | IFR0       | 8 KB       |
| MEM2      | IFR1       | 2 KB       |

#### 45.1.3 Security considerations

This chip doesn't support the control of secure and privilege level. All the access to MBC is considered as secure privilege. You should not set the NonSecure Enable (NSE) bits.

MBC can generate interrupt, when error happens. The MBC secure violation interrupt can be generated by OR the LSB of the four slave domainX error together. The domainX error registers are physically in the block checker.

**NOTE**

TZ-M feature of the module is not supported on this device.

### 45.2 Overview

The Memory Block Checker (MBC) implements access controls for on-chip internal memories based on a fixed-sized block format. MBC provides hardware access control for system bus references targeted at on-chip memory spaces.

Using the pre-programmed region descriptors with fixed-sized block format and their associated access rights, the MBC concurrently monitors system bus transactions and evaluates the appropriateness of each transfer. Memory references with sufficient access control rights are completed, while the references that are not mapped to any region descriptor or have insufficient rights are terminated with an access error response.

#### 45.2.1 Block diagram

The Memory Block Checker (MBC) implements access controls for on-chip internal memories and slave peripherals based on a fixed-sized block format.

See [Figure 202](#) for MBC block diagram focusing on topology and connections.



Figure 202. MBC block diagram

#### 45.2.2 Features

Defines access rights to slave targets defined in MBCs for on-chip memories.

### 45.3 Functional description

This section provides more details on the operation and implementation of MBC.

#### 45.3.1 Memory Block Checker (MBC)

The Memory Block Checker provides access control for system bus references targeted to on-chip internal memories . Using programmed block configuration registers which define the access rights per block, the MBC concurrently monitors system bus transactions and evaluates the appropriateness of each transfer. Memory references that have sufficient access rights are allowed to complete, while references that have insufficient rights are terminated with an access error response.

Refer to the chip-specific section to determine the number and size of blocks for each sub memory supported on this device.

Each MBCm\_DOMd\_BLK\_CFG\_W contains eight access control structures. Each structure is comprised of a 3-bit MBACSEL (Memory Block Access Control Select). The MBACSEL field selects a MBCm\_MEMN\_GLBACr register, which controls the read/write/execute/lock access to the corresponding block. Below table provides the eighth possible access control combinations. In case you are looking for different access combination, such as write and execute allowed but read blocked, you can modify one of the unlocked configurations registers (MBC0\_MEMN\_GLBAC0 or MBC0\_MEMN\_GLBAC4 or MBC0\_MEMN\_GLBAC5) to 0x0000\_3300.

Table below depicts eighth possible access control combinations.

**Table 277. Access control combinations**

| GAC Index | Register name                     | Read | Write | Execute | Lock | Description                                                                                                                                                                                                                                                                                                                                            |
|-----------|-----------------------------------|------|-------|---------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0         | MBC0_MEMN_GLBAC0<br>(0x0000_6600) | 1    | 1     | 0       | 0    | <b>Data flash and unlocked (RW__).</b><br>Default flash behavior with read and write access only. Instruction fetches (execute access) are blocked and generates security violation. Blocks assigned with this access control index can be changed to another index by software. This configuration register is unlocked and updatable by application. |
| 1         | MBC0_MEMN_GLBAC1<br>(0x8000_6600) | 1    | 1     | 0       | 1    | <b>Data flash and locked (RW_L).</b> Read and write operations are allowed but execution is blocked. Blocks assigned with this access control index cannot be changed to another index until next reset.                                                                                                                                               |
| 2         | MBC0_MEMN_GLBAC2<br>(0x8000_5500) | 1    | 0     | 1       | 1    | <b>Read only Memory (ROM) and locked (R_XL)</b><br>Read & execute operations are allowed but write is blocked. Blocks assigned with this access control index cannot be changed to another index until next reset.                                                                                                                                     |
| 3         | MBC0_MEMN_GLBAC3<br>(0x8000_4400) | 1    | 0     | 0       | 1    | <b>Data Read only memory (DROM) and locked (R__L)</b><br>Read operations is allowed but write & execute are blocked. Blocks assigned with this access control index cannot be changed to another index until next reset.                                                                                                                               |
| 4         | MBC0_MEMN_GLBAC4<br>(0x0000_5500) | 1    | 0     | 1       | 0    | <b>Read-Only-Memory (ROM) and un-locked (R_X_)</b><br>Read & execute operations are allowed but write is blocked.<br>Blocks assigned with this access control index can be changed to another index by software.<br>This configuration register is unlocked and updatable by application.                                                              |
| 5         | MBC0_MEMN_GLBAC5<br>(0x0000_1100) | 0    | 0     | 1       | 0    | <b>eXecute-only Memory (XOM) and un-locked (_X_)</b><br>Execute operations are allowed but read & write are blocked.<br>Blocks assigned with this access control index can be changed to another index by software.<br>This configuration register is unlocked and updatable by application.                                                           |

*Table continues on the next page...*

Table 277. Access control combinations (continued)

| GAC Index | Register name                     | Read | Write | Execute | Lock | Description                                                                                                                                                                                                                  |
|-----------|-----------------------------------|------|-------|---------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6         | MBC0_MEMN_GLBAC6<br>(0x8000_1100) | 0    | 0     | 1       | 1    | <b>eXecute-Only-Memory (XOM) and locked (____XL)</b><br><br>Execute operations are allowed but read & write are blocked. Blocks assigned with this access control index cannot be changed to another index until next reset. |
| 7         | MBC0_MEMN_GLBAC7<br>(0x8000_0000) | 0    | 0     | 0       | 1    | <b>Hidden (____L)</b><br><br>Read, Write & execute operations are blocked. Once this access control index is assigned to a block, the memory range associated with block is hidden until next reset.                         |

GLBAC1-7 also have a lock bit MBCm\_MEMn\_GLBACr[LK]. When LK=1, the GLBACr register is read-only until the next reset. Furthermore, if MBCm\_DOMd\_BLK\_CFG\_W[MBACSEL] selects a GLBAC that is locked, the 3-bit MBCACSEL field is also locked until the next reset. GLBAC0 cannot be locked.

#### 45.3.1.1 Memory block hit determination

MBCm\_MEMs\_GLBCFG[NBLK, SIZE\_LOG2] is used to determine which bits of the address correspond to block number.

```
block_n_hit = (addr[MSB:LSB] == n)
where LSB=SIZE_LOG2
MSB=f{NBLKS, LSB}
```

Note that the block hit determination is based only on the address comparison of the first byte being accessed; that is, the MBC does not check the size of the access to make sure it entirely fits within the region.

#### 45.3.1.2 Memory block access evaluation

For a block n hit, the MBC logic evaluates the access rights defined by the MBCm\_DOMd\_BLK\_CFG\_Ww registers. The block number hit selects the appropriate MBCm\_DOMd\_BLK\_CFG\_Ww register to use in the access evaluation. The {R,W,X}, nonsecure and privilege attributes of the access are compared with the MBC global access control policy defined in MBCm\_DOMd\_BLK\_CFG\_W[MBACSEL, NSE] fields.

MBC access evaluation terminates the access with a bus error and reports an access error for only one condition - when the access doesn't have sufficient access rights. By nature, the block checker can only hit in ONE block. And by implementation, there are no "miss" accesses. Accesses outside of the range covered by the MBC are not sent to the MBC. There also aren't any individual block valid bits.

#### 45.3.2 Interrupts

This module outputs an interrupt signal which can be connected to the system's interrupt controller. Please check chip-specific interrupt assignment for details. Interrupt is asserted on detection of access violation by any checker, and it remains asserted until MBCn\_MEM3\_GLBCFG[CLRE] is cleared. This interrupt is in addition to interrupt generated by master after receiving bus error due to access violation by memory block checker . So, system may receive interrupt through different channels but from the same access violation at checker.

### 45.4 External signals

This module has no external signals.

## 45.5 Register descriptions

Unless noted otherwise, the programming model registers can be accessed via 8-, 16- or 32-bit reads and 32-bit write references. Attempted accesses in a different operating mode, using unsupported write data sizes, writes to read-only resources, or access to reserved spaces are terminated with an error unless noted otherwise.

### 45.5.1 MBC register descriptions

#### 45.5.1.1 MBC memory map

MBC0.MBC base address: 4008\_E000h

| Offset | Register                                                           | Width<br>(In bits) | Access | Reset value |
|--------|--------------------------------------------------------------------|--------------------|--------|-------------|
| 0h     | MBC Global Configuration Register (MBC0_MEM0_GLBCFG)               | 32                 | R      | 000D_0010h  |
| 4h     | MBC Global Configuration Register (MBC0_MEM1_GLBCFG)               | 32                 | R      | 000D_0004h  |
| 8h     | MBC Global Configuration Register (MBC0_MEM2_GLBCFG)               | 32                 | R      | 000B_0004h  |
| Ch     | MBC Global Configuration Register (MBC0_MEM3_GLBCFG)               | 32                 | RW     | 0000_0000h  |
| 20h    | MBC Global Access Control (MBC0_MEMN_GLBAC0)                       | 32                 | RW     | 0000_6600h  |
| 24h    | MBC Global Access Control (MBC0_MEMN_GLBAC1)                       | 32                 | RW     | 8000_6600h  |
| 28h    | MBC Global Access Control (MBC0_MEMN_GLBAC2)                       | 32                 | RW     | 8000_5500h  |
| 2Ch    | MBC Global Access Control (MBC0_MEMN_GLBAC3)                       | 32                 | RW     | 8000_4400h  |
| 30h    | MBC Global Access Control (MBC0_MEMN_GLBAC4)                       | 32                 | RW     | 0000_5500h  |
| 34h    | MBC Global Access Control (MBC0_MEMN_GLBAC5)                       | 32                 | RW     | 0000_1100h  |
| 38h    | MBC Global Access Control (MBC0_MEMN_GLBAC6)                       | 32                 | RW     | 8000_1100h  |
| 3Ch    | MBC Global Access Control (MBC0_MEMN_GLBAC7)                       | 32                 | RW     | 8000_0000h  |
| 40h    | MBC Memory Block Configuration Word<br>(MBC0_DOM0_MEM0_BLK_CFG_W0) | 32                 | RW     | 0000_0000h  |
| 44h    | MBC Memory Block Configuration Word<br>(MBC0_DOM0_MEM0_BLK_CFG_W1) | 32                 | RW     | 0000_0000h  |
| 180h   | MBC Memory Block Configuration Word<br>(MBC0_DOM0_MEM1_BLK_CFG_W0) | 32                 | RW     | 0000_0000h  |
| 1A8h   | MBC Memory Block Configuration Word<br>(MBC0_DOM0_MEM2_BLK_CFG_W0) | 32                 | RW     | 0000_0000h  |

#### 45.5.1.2 MBC Global Configuration Register (MBC0\_MEM0\_GLBCFG - MBC0\_MEM3\_GLBCFG)

Offset

| Register         | Offset |
|------------------|--------|
| MBC0_MEM0_GLBCFG | 0h     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Register         | Offset |
|------------------|--------|
| MBC0_MEM1_GLBCFG | 4h     |
| MBC0_MEM2_GLBCFG | 8h     |
| MBC0_MEM3_GLBCFG | Ch     |

### Function

These MBC global configuration read-only registers contain information on the MBC's hardware configuration. Specifically, it defines the number of memory blocks and the size of each block in each MBC mem (r).

### Diagram

|       |                                             |    |    |    |       |    |    |    |    |    |    |           |    |    |    |    |
|-------|---------------------------------------------|----|----|----|-------|----|----|----|----|----|----|-----------|----|----|----|----|
| Bits  | 31                                          | 30 | 29 | 28 | 27    | 26 | 25 | 24 | 23 | 22 | 21 | 20        | 19 | 18 | 17 | 16 |
| R     | 0                                           | 0  |    |    |       |    |    |    |    |    |    | SIZE_LOG2 |    |    |    |    |
| W     | CLRE                                        |    |    |    |       |    |    |    |    |    |    |           |    |    |    |    |
| Reset | See <a href="#">Register reset values</a> . |    |    |    |       |    |    |    |    |    |    |           |    |    |    |    |
| Bits  | 15                                          | 14 | 13 | 12 | 11    | 10 | 9  | 8  | 7  | 6  | 5  | 4         | 3  | 2  | 1  | 0  |
| R     | 0                                           |    |    |    | NBLKS |    |    |    |    |    |    |           |    |    |    |    |
| W     |                                             |    |    |    |       |    |    |    |    |    |    |           |    |    |    |    |
| Reset | See <a href="#">Register reset values</a> . |    |    |    |       |    |    |    |    |    |    |           |    |    |    |    |

### Register reset values

| Register         | Reset value |
|------------------|-------------|
| MBC0_MEM0_GLBCFG | 000D_0010h  |
| MBC0_MEM1_GLBCFG | 000D_0004h  |
| MBC0_MEM2_GLBCFG | 000B_0004h  |
| MBC0_MEM3_GLBCFG | 0000_0000h  |

### Fields

| Field         | Function                                                                                                                                                                                                                                                                                                                                                   |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30<br>CLRE | <p>Clear Error</p> <p>This 2-bit, write-only field controls the clearing of an access violation error and any interrupt due to error, on writing 01b to this field. A write of any value other than 01b has no effect.</p> <p><b>NOTE</b></p> <p>This field is not supported in every instance. The following table includes only supported registers.</p> |

*Table continued from the previous page...*

| Field              | Function                                                               |                    |                                       |
|--------------------|------------------------------------------------------------------------|--------------------|---------------------------------------|
|                    | Instance                                                               | Field supported in | Field not supported in                |
| MBC0.MBC           | MBC0_MEM3_GLBCFG                                                       |                    | MBC0_MEM0_GLBCFG–<br>MBC0_MEM2_GLBCFG |
| 29-21<br>—         | Reserved                                                               |                    |                                       |
| 20-16<br>SIZE_LOG2 | Log2 size per block<br>For example SIZE_LOG2=0x0C is 2^12=4 KB blocks. |                    |                                       |
| 15-10<br>—         | Reserved                                                               |                    |                                       |
| 9-0<br>NBLKS       | Number of blocks in this memory                                        |                    |                                       |

#### 45.5.1.3 MBC Global Access Control (MBC0\_MEMN\_GLBAC0)

##### Offset

| Register         | Offset |
|------------------|--------|
| MBC0_MEMN_GLBAC0 | 20h    |

##### Function

These fully programmable R/W fields define the R/W/X (read/write/execute) access control flags with each of the 4 supported operating modes: SecurePriv, SecureUser, NonsecurePriv, Nonsecure User.

##### NOTE

The lock field (LK) in MBC0\_MEMN\_GLBAC1, MBC0\_MEMN\_GLBAC2, MBC0\_MEMN\_GLBAC3, MBC0\_MEMN\_GLBAC6 and MBC0\_MEMN\_GLBAC7 registers are set to lock state (LK= 1) at reset. Hence these registers cannot be changed and blocks that are assigned to one of these global access control indexes cannot change the access policy index until next reset.

**Diagram**

| Bits  | 31 | 30  | 29  | 28  | 27 | 26  | 25  | 24  | 23 | 22  | 21  | 20  | 19 | 18  | 17  | 16  |
|-------|----|-----|-----|-----|----|-----|-----|-----|----|-----|-----|-----|----|-----|-----|-----|
| R     | 0  |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| W     |    |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| Reset | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   |
| Bits  | 15 | 14  | 13  | 12  | 11 | 10  | 9   | 8   | 7  | 6   | 5   | 4   | 3  | 2   | 1   | 0   |
| R     | 0  | SPR | SPW | SPX | 0  | SUR | SUW | SUX | 0  | NPR | NPW | NPX | 0  | NUR | NUW | NUX |
| W     |    |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| Reset | 0  | 1   | 1   | 0   | 0  | 1   | 1   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   |

**Fields**

| Field      | Function                                                                                                                                                                                 |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-15<br>— | Reserved                                                                                                                                                                                 |
| 14<br>SPR  | SecurePriv Read<br>SecurePriv read access control flag<br>0b - Read access is not allowed in Secure Privilege mode.<br>1b - Read access is allowed in Secure Privilege mode.             |
| 13<br>SPW  | SecurePriv Write<br>SecurePriv write access control flag<br>0b - Write access is not allowed in Secure Privilege mode.<br>1b - Write access is allowed in Secure Privilege mode.         |
| 12<br>SPX  | SecurePriv Execute<br>SecurePriv execute access control flag<br>0b - Execute access is not allowed in Secure Privilege mode.<br>1b - Execute access is allowed in Secure Privilege mode. |
| 11<br>—    | Reserved                                                                                                                                                                                 |
| 10<br>SUR  | SecureUser Read<br>SecureUser read access control flag<br>0b - Read access is not allowed in Secure User mode.<br>1b - Read access is allowed in Secure User mode.                       |
| 9          | SecureUser Write                                                                                                                                                                         |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                             |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SUW      | SecureUser write access control flag<br>0b - Write access is not allowed in Secure User mode.<br>1b - Write access is allowed in Secure User mode.                                                   |
| 8<br>SUX | SecureUser Execute<br>SecureUser execute access control flag<br>0b - Execute access is not allowed in Secure User mode.<br>1b - Execute access is allowed in Secure User mode.                       |
| 7<br>—   | Reserved                                                                                                                                                                                             |
| 6<br>NPR | NonsecurePriv Read<br>NonsecurePriv read access control flag<br>0b - Read access is not allowed in Nonsecure Privilege mode.<br>1b - Read access is allowed in Nonsecure Privilege mode.             |
| 5<br>NPW | NonsecurePriv Write<br>NonsecurePriv write access control flag<br>0b - Write access is not allowed in Nonsecure Privilege mode.<br>1b - Write access is allowed in Nonsecure Privilege mode.         |
| 4<br>NPX | NonsecurePriv Execute<br>NonsecurePriv execute access control flag<br>0b - Execute access is not allowed in Nonsecure Privilege mode.<br>1b - Execute access is allowed in Nonsecure Privilege mode. |
| 3<br>—   | Reserved                                                                                                                                                                                             |
| 2<br>NUR | NonsecureUser Read<br>NonsecureUser read access control flag<br>0b - Read access is not allowed in Nonsecure User mode.<br>1b - Read access is allowed in Nonsecure User mode.                       |
| 1<br>NUW | NonsecureUser Write<br>NonsecureUser write access control flag<br>0b - Write access is not allowed in Nonsecure User mode.<br>1b - Write access is allowed in Nonsecure User mode.                   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                          |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0     | NonsecureUser Execute                                                                                                                                             |
| NUX   | NonsecureUser execute access control flag<br>0b - Execute access is not allowed in Nonsecure User mode.<br>1b - Execute access is allowed in Nonsecure User mode. |

#### 45.5.1.4 MBC Global Access Control (MBC0\_MEMN\_GLBAC1)

##### Offset

| Register         | Offset |
|------------------|--------|
| MBC0_MEMN_GLBAC1 | 24h    |

##### Function

These fully programmable R/W fields define the R/W/X (read/write/execute) access control flags with each of the 4 supported operating modes: SecurePriv, SecureUser, NonsecurePriv, Nonsecure User. The lock bit provides the ability to lock these control access flags and to lock the MBC\_BLK\_CFG[MBACSEL] field when a locked MBC\_MEMN\_GLBAC register is selected.

This register is not writable.

##### NOTE

The lock field (LK) in MBC0\_MEMN\_GLBAC1, MBC0\_MEMN\_GLBAC2, MBC0\_MEMN\_GLBAC3, MBC0\_MEMN\_GLBAC6 and MBC0\_MEMN\_GLBAC7 registers are set to lock state (LK= 1) at reset. Hence these registers cannot be changed and blocks that are assigned to one of these global access control indexes cannot change the access policy index until next reset.

##### Diagram

| Bits  | 31 | 30  | 29  | 28  | 27 | 26  | 25  | 24  | 23 | 22  | 21  | 20  | 19 | 18  | 17  | 16  |
|-------|----|-----|-----|-----|----|-----|-----|-----|----|-----|-----|-----|----|-----|-----|-----|
| R     | 0  |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| W     |    |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| Reset | 1  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   |
| Bits  | 15 | 14  | 13  | 12  | 11 | 10  | 9   | 8   | 7  | 6   | 5   | 4   | 3  | 2   | 1   | 0   |
| R     | 0  | SPR | SPW | SPX | 0  | SUR | SUW | SUX | 0  | NPR | NPW | NPX | 0  | NUR | NUW | NUX |
| W     |    |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| Reset | 0  | 1   | 1   | 0   | 0  | 1   | 1   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   |

**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                     |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>LK   | LOCK<br><br>This 1-bit field provides a mechanism to limit writes to the this register to protect its contents. Once set, this bit remains asserted until the next reset.<br><br>0b - This register is not locked and can be altered.<br>1b - This register is locked and cannot be altered. |
| 30-15<br>— | Reserved                                                                                                                                                                                                                                                                                     |
| 14<br>SPR  | SecurePriv Read<br><br>SecurePriv read access control flag<br><br>0b - Read access is not allowed in Secure Privilege mode.<br>1b - Read access is allowed in Secure Privilege mode.                                                                                                         |
| 13<br>SPW  | SecurePriv Write<br><br>SecurePriv write access control flag<br><br>0b - Write access is not allowed in Secure Privilege mode.<br>1b - Write access is allowed in Secure Privilege mode.                                                                                                     |
| 12<br>SPX  | SecurePriv Execute<br><br>SecurePriv execute access control flag<br><br>0b - Execute access is not allowed in Secure Privilege mode.<br>1b - Execute access is allowed in Secure Privilege mode.                                                                                             |
| 11<br>—    | Reserved                                                                                                                                                                                                                                                                                     |
| 10<br>SUR  | SecureUser Read<br><br>SecureUser read access control flag<br><br>0b - Read access is not allowed in Secure User mode.<br>1b - Read access is allowed in Secure User mode.                                                                                                                   |
| 9<br>SUW   | SecureUser Write<br><br>SecureUser write access control flag<br><br>0b - Write access is not allowed in Secure User mode.<br>1b - Write access is allowed in Secure User mode.                                                                                                               |
| 8<br>SUX   | SecureUser Execute<br><br>SecureUser execute access control flag                                                                                                                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                             |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 0b - Execute access is not allowed in Secure User mode.<br>1b - Execute access is allowed in Secure User mode.                                                                                       |
| 7<br>—   | Reserved                                                                                                                                                                                             |
| 6<br>NPR | NonsecurePriv Read<br>NonsecurePriv read access control flag<br>0b - Read access is not allowed in Nonsecure Privilege mode.<br>1b - Read access is allowed in Nonsecure Privilege mode.             |
| 5<br>NPW | NonsecurePriv Write<br>NonsecurePriv write access control flag<br>0b - Write access is not allowed in Nonsecure Privilege mode.<br>1b - Write access is allowed in Nonsecure Privilege mode.         |
| 4<br>NPX | NonsecurePriv Execute<br>NonsecurePriv execute access control flag<br>0b - Execute access is not allowed in Nonsecure Privilege mode.<br>1b - Execute access is allowed in Nonsecure Privilege mode. |
| 3<br>—   | Reserved                                                                                                                                                                                             |
| 2<br>NUR | NonsecureUser Read<br>NonsecureUser read access control flag<br>0b - Read access is not allowed in Nonsecure User mode.<br>1b - Read access is allowed in Nonsecure User mode.                       |
| 1<br>NUW | NonsecureUser Write<br>NonsecureUser write access control flag<br>0b - Write access is not allowed in Nonsecure User mode.<br>1b - Write access is allowed in Nonsecure User mode.                   |
| 0<br>NUX | NonsecureUser Execute<br>NonsecureUser execute access control flag<br>0b - Execute access is not allowed in Nonsecure User mode.<br>1b - Execute access is allowed in Nonsecure User mode.           |

#### 45.5.1.5 MBC Global Access Control (MBC0\_MEMN\_GLBAC2)

##### Offset

| Register         | Offset |
|------------------|--------|
| MBC0_MEMN_GLBAC2 | 28h    |

##### Function

These fully programmable R/W fields define the R/W/X (read/write/execute) access control flags with each of the 4 supported operating modes: SecurePriv, SecureUser, NonsecurePriv, Nonsecure User. The lock bit provides the ability to lock these control access flags and to lock the MBC\_BLK\_CFG[MBACSEL] field when a locked MBC\_MEMN\_GLBAC register is selected.

This register is not writable.

##### NOTE

The lock field (LK) in MBC0\_MEMN\_GLBAC1, MBC0\_MEMN\_GLBAC2, MBC0\_MEMN\_GLBAC3, MBC0\_MEMN\_GLBAC6 and MBC0\_MEMN\_GLBAC7 registers are set to lock state (LK= 1) at reset. Hence these registers cannot be changed and blocks that are assigned to one of these global access control indexes cannot change the access policy index until next reset.

##### Diagram

| Bits  | 31 | 30  | 29  | 28  | 27 | 26  | 25  | 24  | 23 | 22  | 21  | 20  | 19 | 18  | 17  | 16  |
|-------|----|-----|-----|-----|----|-----|-----|-----|----|-----|-----|-----|----|-----|-----|-----|
| R     | LK |     |     |     |    |     |     |     | 0  |     |     |     |    |     |     |     |
| W     |    |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| Reset | 1  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   |
| Bits  | 15 | 14  | 13  | 12  | 11 | 10  | 9   | 8   | 7  | 6   | 5   | 4   | 3  | 2   | 1   | 0   |
| R     | 0  | SPR | SPW | SPX | 0  | SUR | SUW | SUX | 0  | NPR | NPW | NPX | 0  | NUR | NUW | NUX |
| W     |    |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| Reset | 0  | 1   | 0   | 1   | 0  | 1   | 0   | 1   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   |

##### Fields

| Field      | Function                                                                                                                                                                                                                                                                                     |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>LK   | LOCK<br><br>This 1-bit field provides a mechanism to limit writes to the this register to protect its contents. Once set, this bit remains asserted until the next reset.<br><br>0b - This register is not locked and can be altered.<br>1b - This register is locked and cannot be altered. |
| 30-15<br>— | Reserved                                                                                                                                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                 |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14<br>SPR | SecurePriv Read<br>SecurePriv read access control flag<br>0b - Read access is not allowed in Secure Privilege mode.<br>1b - Read access is allowed in Secure Privilege mode.             |
| 13<br>SPW | SecurePriv Write<br>SecurePriv write access control flag<br>0b - Write access is not allowed in Secure Privilege mode.<br>1b - Write access is allowed in Secure Privilege mode.         |
| 12<br>SPX | SecurePriv Execute<br>SecurePriv execute access control flag<br>0b - Execute access is not allowed in Secure Privilege mode.<br>1b - Execute access is allowed in Secure Privilege mode. |
| 11<br>—   | Reserved                                                                                                                                                                                 |
| 10<br>SUR | SecureUser Read<br>SecureUser read access control flag<br>0b - Read access is not allowed in Secure User mode.<br>1b - Read access is allowed in Secure User mode.                       |
| 9<br>SUW  | SecureUser Write<br>SecureUser write access control flag<br>0b - Write access is not allowed in Secure User mode.<br>1b - Write access is allowed in Secure User mode.                   |
| 8<br>SUX  | SecureUser Execute<br>SecureUser execute access control flag<br>0b - Execute access is not allowed in Secure User mode.<br>1b - Execute access is allowed in Secure User mode.           |
| 7<br>—    | Reserved                                                                                                                                                                                 |
| 6<br>NPR  | NonsecurePriv Read<br>NonsecurePriv read access control flag                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                             |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 0b - Read access is not allowed in Nonsecure Privilege mode.<br>1b - Read access is allowed in Nonsecure Privilege mode.                                                                             |
| 5<br>NPW | NonsecurePriv Write<br>NonsecurePriv write access control flag<br>0b - Write access is not allowed in Nonsecure Privilege mode.<br>1b - Write access is allowed in Nonsecure Privilege mode.         |
| 4<br>NPX | NonsecurePriv Execute<br>NonsecurePriv execute access control flag<br>0b - Execute access is not allowed in Nonsecure Privilege mode.<br>1b - Execute access is allowed in Nonsecure Privilege mode. |
| 3<br>—   | Reserved                                                                                                                                                                                             |
| 2<br>NUR | NonsecureUser Read<br>NonsecureUser read access control flag<br>0b - Read access is not allowed in Nonsecure User mode.<br>1b - Read access is allowed in Nonsecure User mode.                       |
| 1<br>NUW | NonsecureUser Write<br>NonsecureUser write access control flag<br>0b - Write access is not allowed in Nonsecure User mode.<br>1b - Write access is allowed in Nonsecure User mode.                   |
| 0<br>NUX | NonsecureUser Execute<br>NonsecureUser execute access control flag<br>0b - Execute access is not allowed in Nonsecure User mode.<br>1b - Execute access is allowed in Nonsecure User mode.           |

#### 45.5.1.6 MBC Global Access Control (MBC0\_MEMN\_GLBAC3)

##### Offset

| Register         | Offset |
|------------------|--------|
| MBC0_MEMN_GLBAC3 | 2Ch    |

**Function**

These fully programmable R/W fields define the R/W/X (read/write/execute) access control flags with each of the 4 supported operating modes: SecurePriv, SecureUser, NonsecurePriv, Nonsecure User. The lock bit provides the ability to lock these control access flags and to lock the MBC\_BLK\_CFG[MBACSEL] field when a locked MBC\_MEMN\_GLBAC register is selected.

This register is not writable.

**NOTE**

The lock field (LK) in MBC0\_MEMN\_GLBAC1, MBC0\_MEMN\_GLBAC2, MBC0\_MEMN\_GLBAC3, MBC0\_MEMN\_GLBAC6 and MBC0\_MEMN\_GLBAC7 registers are set to lock state (LK= 1) at reset. Hence these registers cannot be changed and blocks that are assigned to one of these global access control indexes cannot change the access policy index until next reset.

**Diagram**

| Bits  | 31 | 30  | 29  | 28  | 27 | 26  | 25  | 24  | 23 | 22  | 21  | 20  | 19 | 18  | 17  | 16  |
|-------|----|-----|-----|-----|----|-----|-----|-----|----|-----|-----|-----|----|-----|-----|-----|
| R     | LK | 0   |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| W     |    |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| Reset | 1  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   |
| Bits  | 15 | 14  | 13  | 12  | 11 | 10  | 9   | 8   | 7  | 6   | 5   | 4   | 3  | 2   | 1   | 0   |
| R     | 0  | SPR | SPW | SPX | 0  | SUR | SUW | SUX | 0  | NPR | NPW | NPX | 0  | NUR | NUW | NUX |
| W     |    |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| Reset | 0  | 1   | 0   | 0   | 0  | 1   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   |

**Fields**

| Field | Function                                                                                                                                                                                                                                                                                 |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | LOCK                                                                                                                                                                                                                                                                                     |
| LK    | <p>This 1-bit field provides a mechanism to limit writes to the this register to protect its contents. Once set, this bit remains asserted until the next reset.</p> <p>0b - This register is not locked and can be altered.<br/>1b - This register is locked and cannot be altered.</p> |
| 30-15 | Reserved                                                                                                                                                                                                                                                                                 |
| —     |                                                                                                                                                                                                                                                                                          |
| 14    | SecurePriv Read                                                                                                                                                                                                                                                                          |
| SPR   | <p>SecurePriv read access control flag</p> <p>0b - Read access is not allowed in Secure Privilege mode.<br/>1b - Read access is allowed in Secure Privilege mode.</p>                                                                                                                    |
| 13    | SecurePriv Write                                                                                                                                                                                                                                                                         |
| SPW   | SecurePriv write access control flag                                                                                                                                                                                                                                                     |

Table continues on the next page...

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                     |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | 0b - Write access is not allowed in Secure Privilege mode.<br>1b - Write access is allowed in Secure Privilege mode.                                                                         |
| 12<br>SPX | SecurePriv Execute<br>SecurePriv execute access control flag<br>0b - Execute access is not allowed in Secure Privilege mode.<br>1b - Execute access is allowed in Secure Privilege mode.     |
| 11<br>—   | Reserved                                                                                                                                                                                     |
| 10<br>SUR | SecureUser Read<br>SecureUser read access control flag<br>0b - Read access is not allowed in Secure User mode.<br>1b - Read access is allowed in Secure User mode.                           |
| 9<br>SUW  | SecureUser Write<br>SecureUser write access control flag<br>0b - Write access is not allowed in Secure User mode.<br>1b - Write access is allowed in Secure User mode.                       |
| 8<br>SUX  | SecureUser Execute<br>SecureUser execute access control flag<br>0b - Execute access is not allowed in Secure User mode.<br>1b - Execute access is allowed in Secure User mode.               |
| 7<br>—    | Reserved                                                                                                                                                                                     |
| 6<br>NPR  | NonsecurePriv Read<br>NonsecurePriv read access control flag<br>0b - Read access is not allowed in Nonsecure Privilege mode.<br>1b - Read access is allowed in Nonsecure Privilege mode.     |
| 5<br>NPW  | NonsecurePriv Write<br>NonsecurePriv write access control flag<br>0b - Write access is not allowed in Nonsecure Privilege mode.<br>1b - Write access is allowed in Nonsecure Privilege mode. |
| 4         | NonsecurePriv Execute                                                                                                                                                                        |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                   |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NPX      | NonsecurePriv execute access control flag<br>0b - Execute access is not allowed in Nonsecure Privilege mode.<br>1b - Execute access is allowed in Nonsecure Privilege mode.                |
| 3<br>—   | Reserved                                                                                                                                                                                   |
| 2<br>NUR | NonsecureUser Read<br>NonsecureUser read access control flag<br>0b - Read access is not allowed in Nonsecure User mode.<br>1b - Read access is allowed in Nonsecure User mode.             |
| 1<br>NUW | NonsecureUser Write<br>NonsecureUser write access control flag<br>0b - Write access is not allowed in Nonsecure User mode.<br>1b - Write access is allowed in Nonsecure User mode.         |
| 0<br>NUX | NonsecureUser Execute<br>NonsecureUser execute access control flag<br>0b - Execute access is not allowed in Nonsecure User mode.<br>1b - Execute access is allowed in Nonsecure User mode. |

#### 45.5.1.7 MBC Global Access Control (MBC0\_MEMN\_GLBAC4)

##### Offset

| Register         | Offset |
|------------------|--------|
| MBC0_MEMN_GLBAC4 | 30h    |

##### Function

These fully programmable R/W fields define the R/W/X (read/write/execute) access control flags with each of the 4 supported operating modes: SecurePriv, SecureUser, NonsecurePriv, Nonsecure User. The lock bit provides the ability to lock these control access flags and to lock the MBC\_BLK\_CFG[MBACSEL] field when a locked MBC\_MEMN\_GLBAC register is selected.

---

##### NOTE

The lock field (LK) in MBC0\_MEMN\_GLBAC1, MBC0\_MEMN\_GLBAC2, MBC0\_MEMN\_GLBAC3, MBC0\_MEMN\_GLBAC6 and MBC0\_MEMN\_GLBAC7 registers are set to lock state (LK= 1) at reset. Hence these registers cannot be changed and blocks that are assigned to one of these global access control indexes cannot change the access policy index until next reset.

**Diagram**

| Bits  | 31 | 30  | 29  | 28  | 27 | 26  | 25  | 24  | 23 | 22  | 21  | 20  | 19 | 18  | 17  | 16  |
|-------|----|-----|-----|-----|----|-----|-----|-----|----|-----|-----|-----|----|-----|-----|-----|
| R     | LK |     |     |     |    |     |     |     | 0  |     |     |     |    |     |     |     |
| W     |    |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| Reset | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   |
| Bits  | 15 | 14  | 13  | 12  | 11 | 10  | 9   | 8   | 7  | 6   | 5   | 4   | 3  | 2   | 1   | 0   |
| R     | 0  | SPR | SPW | SPX | 0  | SUR | SUW | SUX | 0  | NPR | NPW | NPX | 0  | NUR | NUW | NUX |
| W     |    |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| Reset | 0  | 1   | 0   | 1   | 0  | 1   | 0   | 1   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   |

**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                     |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>LK   | LOCK<br><br>This 1-bit field provides a mechanism to limit writes to the this register to protect its contents. Once set, this bit remains asserted until the next reset.<br><br>0b - This register is not locked and can be altered.<br>1b - This register is locked and cannot be altered. |
| 30-15<br>— | Reserved                                                                                                                                                                                                                                                                                     |
| 14<br>SPR  | SecurePriv Read<br><br>SecurePriv read access control flag<br><br>0b - Read access is not allowed in Secure Privilege mode.<br>1b - Read access is allowed in Secure Privilege mode.                                                                                                         |
| 13<br>SPW  | SecurePriv Write<br><br>SecurePriv write access control flag<br><br>0b - Write access is not allowed in Secure Privilege mode.<br>1b - Write access is allowed in Secure Privilege mode.                                                                                                     |
| 12<br>SPX  | SecurePriv Execute<br><br>SecurePriv execute access control flag<br><br>0b - Execute access is not allowed in Secure Privilege mode.<br>1b - Execute access is allowed in Secure Privilege mode.                                                                                             |
| 11<br>—    | Reserved                                                                                                                                                                                                                                                                                     |
| 10         | SecureUser Read                                                                                                                                                                                                                                                                              |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                                                                                                                    |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SUR   | SecureUser read access control flag<br>0b - Read access is not allowed in Secure User mode.<br>1b - Read access is allowed in Secure User mode.                             |
| 9     | SecureUser Write                                                                                                                                                            |
| SUW   | SecureUser write access control flag<br>0b - Write access is not allowed in Secure User mode.<br>1b - Write access is allowed in Secure User mode.                          |
| 8     | SecureUser Execute                                                                                                                                                          |
| SUX   | SecureUser execute access control flag<br>0b - Execute access is not allowed in Secure User mode.<br>1b - Execute access is allowed in Secure User mode.                    |
| 7     | Reserved                                                                                                                                                                    |
| —     |                                                                                                                                                                             |
| 6     | NonsecurePriv Read                                                                                                                                                          |
| NPR   | NonsecurePriv read access control flag<br>0b - Read access is not allowed in Nonsecure Privilege mode.<br>1b - Read access is allowed in Nonsecure Privilege mode.          |
| 5     | NonsecurePriv Write                                                                                                                                                         |
| NPW   | NonsecurePriv write access control flag<br>0b - Write access is not allowed in Nonsecure Privilege mode.<br>1b - Write access is allowed in Nonsecure Privilege mode.       |
| 4     | NonsecurePriv Execute                                                                                                                                                       |
| NPX   | NonsecurePriv execute access control flag<br>0b - Execute access is not allowed in Nonsecure Privilege mode.<br>1b - Execute access is allowed in Nonsecure Privilege mode. |
| 3     | Reserved                                                                                                                                                                    |
| —     |                                                                                                                                                                             |
| 2     | NonsecureUser Read                                                                                                                                                          |
| NUR   | NonsecureUser read access control flag<br>0b - Read access is not allowed in Nonsecure User mode.<br>1b - Read access is allowed in Nonsecure User mode.                    |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                   |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>NUW | NonsecureUser Write<br>NonsecureUser write access control flag<br>0b - Write access is not allowed in Nonsecure User mode.<br>1b - Write access is allowed in Nonsecure User mode.         |
| 0<br>NUX | NonsecureUser Execute<br>NonsecureUser execute access control flag<br>0b - Execute access is not allowed in Nonsecure User mode.<br>1b - Execute access is allowed in Nonsecure User mode. |

#### 45.5.1.8 MBC Global Access Control (MBC0\_MEMN\_GLBAC5)

##### Offset

| Register         | Offset |
|------------------|--------|
| MBC0_MEMN_GLBAC5 | 34h    |

##### Function

These fully programmable R/W fields define the R/W/X (read/write/execute) access control flags with each of the 4 supported operating modes: SecurePriv, SecureUser, NonsecurePriv, Nonsecure User. The lock bit provides the ability to lock these control access flags and to lock the MBC\_BLK\_CFG[MBACSEL] field when a locked MBC\_MEMN\_GLBAC register is selected.

##### NOTE

The lock field (LK) in MBC0\_MEMN\_GLBAC1, MBC0\_MEMN\_GLBAC2, MBC0\_MEMN\_GLBAC3, MBC0\_MEMN\_GLBAC6 and MBC0\_MEMN\_GLBAC7 registers are set to lock state (LK= 1) at reset. Hence these registers cannot be changed and blocks that are assigned to one of these global access control indexes cannot change the access policy index until next reset.

##### Diagram

| Bits  | 31 | 30  | 29  | 28  | 27 | 26  | 25  | 24  | 23 | 22  | 21  | 20  | 19 | 18  | 17  | 16  |
|-------|----|-----|-----|-----|----|-----|-----|-----|----|-----|-----|-----|----|-----|-----|-----|
| R     | LK |     |     |     |    |     |     |     | 0  |     |     |     |    |     |     |     |
| W     |    |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| Reset | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   |
| Bits  | 15 | 14  | 13  | 12  | 11 | 10  | 9   | 8   | 7  | 6   | 5   | 4   | 3  | 2   | 1   | 0   |
| R     | 0  | SPR | SPW | SPX | 0  | SUR | SUW | SUX | 0  | NPR | NPW | NPX | 0  | NUR | NUW | NUX |
| W     |    |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| Reset | 0  | 0   | 0   | 1   | 0  | 0   | 0   | 1   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   |

**Fields**

| Field      | Function                                                                                                                                                                                                                                                                                     |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>LK   | LOCK<br><br>This 1-bit field provides a mechanism to limit writes to the this register to protect its contents. Once set, this bit remains asserted until the next reset.<br><br>0b - This register is not locked and can be altered.<br>1b - This register is locked and cannot be altered. |
| 30-15<br>— | Reserved                                                                                                                                                                                                                                                                                     |
| 14<br>SPR  | SecurePriv Read<br><br>SecurePriv read access control flag<br><br>0b - Read access is not allowed in Secure Privilege mode.<br>1b - Read access is allowed in Secure Privilege mode.                                                                                                         |
| 13<br>SPW  | SecurePriv Write<br><br>SecurePriv write access control flag<br><br>0b - Write access is not allowed in Secure Privilege mode.<br>1b - Write access is allowed in Secure Privilege mode.                                                                                                     |
| 12<br>SPX  | SecurePriv Execute<br><br>SecurePriv execute access control flag<br><br>0b - Execute access is not allowed in Secure Privilege mode.<br>1b - Execute access is allowed in Secure Privilege mode.                                                                                             |
| 11<br>—    | Reserved                                                                                                                                                                                                                                                                                     |
| 10<br>SUR  | SecureUser Read<br><br>SecureUser read access control flag<br><br>0b - Read access is not allowed in Secure User mode.<br>1b - Read access is allowed in Secure User mode.                                                                                                                   |
| 9<br>SUW   | SecureUser Write<br><br>SecureUser write access control flag<br><br>0b - Write access is not allowed in Secure User mode.<br>1b - Write access is allowed in Secure User mode.                                                                                                               |
| 8<br>SUX   | SecureUser Execute<br><br>SecureUser execute access control flag                                                                                                                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                             |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 0b - Execute access is not allowed in Secure User mode.<br>1b - Execute access is allowed in Secure User mode.                                                                                       |
| 7<br>—   | Reserved                                                                                                                                                                                             |
| 6<br>NPR | NonsecurePriv Read<br>NonsecurePriv read access control flag<br>0b - Read access is not allowed in Nonsecure Privilege mode.<br>1b - Read access is allowed in Nonsecure Privilege mode.             |
| 5<br>NPW | NonsecurePriv Write<br>NonsecurePriv write access control flag<br>0b - Write access is not allowed in Nonsecure Privilege mode.<br>1b - Write access is allowed in Nonsecure Privilege mode.         |
| 4<br>NPX | NonsecurePriv Execute<br>NonsecurePriv execute access control flag<br>0b - Execute access is not allowed in Nonsecure Privilege mode.<br>1b - Execute access is allowed in Nonsecure Privilege mode. |
| 3<br>—   | Reserved                                                                                                                                                                                             |
| 2<br>NUR | NonsecureUser Read<br>NonsecureUser read access control flag<br>0b - Read access is not allowed in Nonsecure User mode.<br>1b - Read access is allowed in Nonsecure User mode.                       |
| 1<br>NUW | NonsecureUser Write<br>NonsecureUser write access control flag<br>0b - Write access is not allowed in Nonsecure User mode.<br>1b - Write access is allowed in Nonsecure User mode.                   |
| 0<br>NUX | NonsecureUser Execute<br>NonsecureUser execute access control flag<br>0b - Execute access is not allowed in Nonsecure User mode.<br>1b - Execute access is allowed in Nonsecure User mode.           |

#### 45.5.1.9 MBC Global Access Control (MBC0\_MEMN\_GLBAC6)

##### Offset

| Register         | Offset |
|------------------|--------|
| MBC0_MEMN_GLBAC6 | 38h    |

##### Function

These fully programmable R/W fields define the R/W/X (read/write/execute) access control flags with each of the 4 supported operating modes: SecurePriv, SecureUser, NonsecurePriv, Nonsecure User. The lock bit provides the ability to lock these control access flags and to lock the MBC\_BLK\_CFG[MBACSEL] field when a locked MBC\_MEMN\_GLBAC register is selected.

This register is not writable.

##### NOTE

The lock field (LK) in MBC0\_MEMN\_GLBAC1, MBC0\_MEMN\_GLBAC2, MBC0\_MEMN\_GLBAC3, MBC0\_MEMN\_GLBAC6 and MBC0\_MEMN\_GLBAC7 registers are set to lock state (LK= 1) at reset. Hence these registers cannot be changed and blocks that are assigned to one of these global access control indexes cannot change the access policy index until next reset.

##### Diagram

| Bits  | 31 | 30  | 29  | 28  | 27 | 26  | 25  | 24  | 23 | 22  | 21  | 20  | 19 | 18  | 17  | 16  |
|-------|----|-----|-----|-----|----|-----|-----|-----|----|-----|-----|-----|----|-----|-----|-----|
| R     | LK |     |     |     |    |     |     |     | 0  |     |     |     |    |     |     |     |
| W     |    |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| Reset | 1  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   |
| Bits  | 15 | 14  | 13  | 12  | 11 | 10  | 9   | 8   | 7  | 6   | 5   | 4   | 3  | 2   | 1   | 0   |
| R     | 0  | SPR | SPW | SPX | 0  | SUR | SUW | SUX | 0  | NPR | NPW | NPX | 0  | NUR | NUW | NUX |
| W     |    |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| Reset | 0  | 0   | 0   | 1   | 0  | 0   | 0   | 1   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   |

##### Fields

| Field      | Function                                                                                                                                                                                                                                                                                     |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>LK   | LOCK<br><br>This 1-bit field provides a mechanism to limit writes to the this register to protect its contents. Once set, this bit remains asserted until the next reset.<br><br>0b - This register is not locked and can be altered.<br>1b - This register is locked and cannot be altered. |
| 30-15<br>— | Reserved                                                                                                                                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                 |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14<br>SPR | SecurePriv Read<br>SecurePriv read access control flag<br>0b - Read access is not allowed in Secure Privilege mode.<br>1b - Read access is allowed in Secure Privilege mode.             |
| 13<br>SPW | SecurePriv Write<br>SecurePriv write access control flag<br>0b - Write access is not allowed in Secure Privilege mode.<br>1b - Write access is allowed in Secure Privilege mode.         |
| 12<br>SPX | SecurePriv Execute<br>SecurePriv execute access control flag<br>0b - Execute access is not allowed in Secure Privilege mode.<br>1b - Execute access is allowed in Secure Privilege mode. |
| 11<br>—   | Reserved                                                                                                                                                                                 |
| 10<br>SUR | SecureUser Read<br>SecureUser read access control flag<br>0b - Read access is not allowed in Secure User mode.<br>1b - Read access is allowed in Secure User mode.                       |
| 9<br>SUW  | SecureUser Write<br>SecureUser write access control flag<br>0b - Write access is not allowed in Secure User mode.<br>1b - Write access is allowed in Secure User mode.                   |
| 8<br>SUX  | SecureUser Execute<br>SecureUser execute access control flag<br>0b - Execute access is not allowed in Secure User mode.<br>1b - Execute access is allowed in Secure User mode.           |
| 7<br>—    | Reserved                                                                                                                                                                                 |
| 6<br>NPR  | NonsecurePriv Read<br>NonsecurePriv read access control flag                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                             |
|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | 0b - Read access is not allowed in Nonsecure Privilege mode.<br>1b - Read access is allowed in Nonsecure Privilege mode.                                                                             |
| 5<br>NPW | NonsecurePriv Write<br>NonsecurePriv write access control flag<br>0b - Write access is not allowed in Nonsecure Privilege mode.<br>1b - Write access is allowed in Nonsecure Privilege mode.         |
| 4<br>NPX | NonsecurePriv Execute<br>NonsecurePriv execute access control flag<br>0b - Execute access is not allowed in Nonsecure Privilege mode.<br>1b - Execute access is allowed in Nonsecure Privilege mode. |
| 3<br>—   | Reserved                                                                                                                                                                                             |
| 2<br>NUR | NonsecureUser Read<br>NonsecureUser read access control flag<br>0b - Read access is not allowed in Nonsecure User mode.<br>1b - Read access is allowed in Nonsecure User mode.                       |
| 1<br>NUW | NonsecureUser Write<br>NonsecureUser write access control flag<br>0b - Write access is not allowed in Nonsecure User mode.<br>1b - Write access is allowed in Nonsecure User mode.                   |
| 0<br>NUX | NonsecureUser Execute<br>NonsecureUser execute access control flag<br>0b - Execute access is not allowed in Nonsecure User mode.<br>1b - Execute access is allowed in Nonsecure User mode.           |

#### 45.5.1.10 MBC Global Access Control (MBC0\_MEMN\_GLBAC7)

##### Offset

| Register         | Offset |
|------------------|--------|
| MBC0_MEMN_GLBAC7 | 3Ch    |

**Function**

These fully programmable R/W fields define the R/W/X (read/write/execute) access control flags with each of the 4 supported operating modes: SecurePriv, SecureUser, NonsecurePriv, Nonsecure User. The lock bit provides the ability to lock these control access flags and to lock the MBC\_BLK\_CFG[MBACSEL] field when a locked MBC\_MEMN\_GLBAC register is selected.

This register is not writable.

**NOTE**

The lock field (LK) in MBC0\_MEMN\_GLBAC1, MBC0\_MEMN\_GLBAC2, MBC0\_MEMN\_GLBAC3, MBC0\_MEMN\_GLBAC6 and MBC0\_MEMN\_GLBAC7 registers are set to lock state (LK= 1) at reset. Hence these registers cannot be changed and blocks that are assigned to one of these global access control indexes cannot change the access policy index until next reset.

**Diagram**

| Bits  | 31 | 30  | 29  | 28  | 27 | 26  | 25  | 24  | 23 | 22  | 21  | 20  | 19 | 18  | 17  | 16  |
|-------|----|-----|-----|-----|----|-----|-----|-----|----|-----|-----|-----|----|-----|-----|-----|
| R     | LK | 0   |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| W     |    |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| Reset | 1  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   |
| Bits  | 15 | 14  | 13  | 12  | 11 | 10  | 9   | 8   | 7  | 6   | 5   | 4   | 3  | 2   | 1   | 0   |
| R     | 0  | SPR | SPW | SPX | 0  | SUR | SUW | SUX | 0  | NPR | NPW | NPX | 0  | NUR | NUW | NUX |
| W     |    |     |     |     |    |     |     |     |    |     |     |     |    |     |     |     |
| Reset | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   | 0  | 0   | 0   | 0   |

**Fields**

| Field | Function                                                                                                                                                                                                                                                                                 |
|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | LOCK                                                                                                                                                                                                                                                                                     |
| LK    | <p>This 1-bit field provides a mechanism to limit writes to the this register to protect its contents. Once set, this bit remains asserted until the next reset.</p> <p>0b - This register is not locked and can be altered.<br/>1b - This register is locked and cannot be altered.</p> |
| 30-15 | Reserved                                                                                                                                                                                                                                                                                 |
| —     |                                                                                                                                                                                                                                                                                          |
| 14    | SecurePriv Read                                                                                                                                                                                                                                                                          |
| SPR   | <p>SecurePriv read access control flag</p> <p>0b - Read access is not allowed in Secure Privilege mode.<br/>1b - Read access is allowed in Secure Privilege mode.</p>                                                                                                                    |
| 13    | SecurePriv Write                                                                                                                                                                                                                                                                         |
| SPW   | SecurePriv write access control flag                                                                                                                                                                                                                                                     |

Table continues on the next page...

*Table continued from the previous page...*

| Field     | Function                                                                                                                                                                                     |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | 0b - Write access is not allowed in Secure Privilege mode.<br>1b - Write access is allowed in Secure Privilege mode.                                                                         |
| 12<br>SPX | SecurePriv Execute<br>SecurePriv execute access control flag<br>0b - Execute access is not allowed in Secure Privilege mode.<br>1b - Execute access is allowed in Secure Privilege mode.     |
| 11<br>—   | Reserved                                                                                                                                                                                     |
| 10<br>SUR | SecureUser Read<br>SecureUser read access control flag<br>0b - Read access is not allowed in Secure User mode.<br>1b - Read access is allowed in Secure User mode.                           |
| 9<br>SUW  | SecureUser Write<br>SecureUser write access control flag<br>0b - Write access is not allowed in Secure User mode.<br>1b - Write access is allowed in Secure User mode.                       |
| 8<br>SUX  | SecureUser Execute<br>SecureUser execute access control flag<br>0b - Execute access is not allowed in Secure User mode.<br>1b - Execute access is allowed in Secure User mode.               |
| 7<br>—    | Reserved                                                                                                                                                                                     |
| 6<br>NPR  | NonsecurePriv Read<br>NonsecurePriv read access control flag<br>0b - Read access is not allowed in Nonsecure Privilege mode.<br>1b - Read access is allowed in Nonsecure Privilege mode.     |
| 5<br>NPW  | NonsecurePriv Write<br>NonsecurePriv write access control flag<br>0b - Write access is not allowed in Nonsecure Privilege mode.<br>1b - Write access is allowed in Nonsecure Privilege mode. |
| 4         | NonsecurePriv Execute                                                                                                                                                                        |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field    | Function                                                                                                                                                                                   |
|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NPX      | NonsecurePriv execute access control flag<br>0b - Execute access is not allowed in Nonsecure Privilege mode.<br>1b - Execute access is allowed in Nonsecure Privilege mode.                |
| 3<br>—   | Reserved                                                                                                                                                                                   |
| 2<br>NUR | NonsecureUser Read<br>NonsecureUser read access control flag<br>0b - Read access is not allowed in Nonsecure User mode.<br>1b - Read access is allowed in Nonsecure User mode.             |
| 1<br>NUW | NonsecureUser Write<br>NonsecureUser write access control flag<br>0b - Write access is not allowed in Nonsecure User mode.<br>1b - Write access is allowed in Nonsecure User mode.         |
| 0<br>NUX | NonsecureUser Execute<br>NonsecureUser execute access control flag<br>0b - Execute access is not allowed in Nonsecure User mode.<br>1b - Execute access is allowed in Nonsecure User mode. |

#### 45.5.1.11 MBC Memory Block Configuration Word (MBC0\_DOM0\_MEM0\_BLK\_CFG\_W0 - MBC0\_DOM0\_MEM2\_BLK\_CFG\_W0)

##### Offset

| Register                   | Offset |
|----------------------------|--------|
| MBC0_DOM0_MEM0_B_LK_CFG_W0 | 40h    |
| MBC0_DOM0_MEM0_B_LK_CFG_W1 | 44h    |
| MBC0_DOM0_MEM1_B_LK_CFG_W0 | 180h   |
| MBC0_DOM0_MEM2_B_LK_CFG_W0 | 1A8h   |

##### Function

MBC[m]\_DOM[d]\_MEM[s]\_BLK\_CFG\_W[w], where,

- m - mbc index

- d - domain index
- s - memory slave index
- w - word index

These registers are read/write for both the alternate view of the NSE bit and the 3-bit MBACSEL field. This is an array of 4 bit fields defining the block configuration for the given submemory. Each 4-bit field includes an alternative view of the associated NSE bit plus a 3-bit access control select that selects the global access control value that applies to the referenced memory block.

For a given memory block, B, if the value programmed in the MBACSELn field selects a locked MBC\_MEMN\_GLBACr register, the MBACSEL field is locked until the next reset. Depending on BLK\_CFG\_W, the NSEn/MBASELn fields correspond to different blocks. The following table describes the relationship between W (word index) and B (block number).

MEM0 supports up to 512 blocks ; W0 - W63

MEM1-3 supports up to 64 block ; W0 - W7

---

#### NOTE

This register is shown with fields such that it covers entire 32 bit register. However, actual fields may be less if number of blocks are such that fields don't align to 32 bits. These absent fields may be shown but user can refer to table below to deduce actual fields and treat absent fields as reserved.

Table 278. Block Config Word to Block Number Relationship

| Block Config Word              | NSE7/<br>MBACSEL7 | NSE6/<br>MBACSEL6 | NSE5/<br>MBACSEL5 | NSE4/<br>MBACSEL4 | NSE3/<br>MBACSEL3 | NSE2/<br>MBACSEL2 | NSE1/<br>MBACSEL1 | NSE0/<br>MBACSEL0 |
|--------------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|
| W0                             | block 7           | block 6           | block 5           | block 4           | block 3           | block 2           | block 1           | block 0           |
| W1                             | block 15          | block 14          | block 13          | block 12          | block 11          | block 10          | block 9           | block 8           |
| W2                             | block 23          | block 22          | block 21          | block 20          | block 19          | block 18          | block 17          | block 16          |
| W3                             | block 31          | block 30          | block 29          | block 28          | block 27          | block 26          | block 25          | block 24          |
| W4                             | block 39          | block 38          | block 37          | block 36          | block 35          | block 34          | block 33          | block 32          |
| W5                             | block 47          | block 46          | block 45          | block 44          | block 43          | block 42          | block 41          | block 40          |
| W6                             | block 55          | block 54          | block 53          | block 52          | block 51          | block 50          | block 49          | block 48          |
| W7                             | block 63          | block 62          | block 61          | block 60          | block 59          | block 58          | block 57          | block 56          |
| For MEM0, block 64 - block 511 |                   |                   |                   |                   |                   |                   |                   |                   |
| W8                             | block 71          | block 70          | block 69          | block 68          | block 67          | block 66          | block 65          | block 64          |
|                                |                   |                   |                   |                   |                   |                   |                   |                   |
| W63                            | block 511         | block 510         | block 509         | block 508         | block 507         | block 506         | block 505         | block 504         |

**Diagram**

| Bits  | 31   | 30       | 29 | 28 | 27   | 26       | 25 | 24 | 23   | 22       | 21 | 20 | 19   | 18       | 17 | 16 |
|-------|------|----------|----|----|------|----------|----|----|------|----------|----|----|------|----------|----|----|
| R     | NSE7 | MBACSEL7 |    |    | NSE6 | MBACSEL6 |    |    | NSE5 | MBACSEL5 |    |    | NSE4 | MBACSEL4 |    |    |
| W     |      |          |    |    |      |          |    |    |      |          |    |    |      |          |    |    |
| Reset | 0    | 0        | 0  | 0  | 0    | 0        | 0  | 0  | 0    | 0        | 0  | 0  | 0    | 0        | 0  | 0  |
| Bits  | 15   | 14       | 13 | 12 | 11   | 10       | 9  | 8  | 7    | 6        | 5  | 4  | 3    | 2        | 1  | 0  |
| R     | NSE3 | MBACSEL3 |    |    | NSE2 | MBACSEL2 |    |    | NSE1 | MBACSEL1 |    |    | NSE0 | MBACSEL0 |    |    |
| W     |      |          |    |    |      |          |    |    |      |          |    |    |      |          |    |    |
| Reset | 0    | 0        | 0  | 0  | 0    | 0        | 0  | 0  | 0    | 0        | 0  | 0  | 0    | 0        | 0  | 0  |

**Fields**

| Field             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31<br>NSE7        | <p>NonSecure Enable for block B</p> <p>0b - Secure accesses to block B are based on corresponding MBACSEL field in this register (MBCm_DOMd_MEMs_BLK_Cfg_Ww[MBACSEL]), nonsecure accesses to block B are not allowed.</p> <p>1b - Secure accesses to block B are not allowed, nonsecure accesses to block B are based on corresponding MBACSEL field in this register (MBCm_DOMd_MEMs_BLK_Cfg_Ww[MBACSEL]).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 30-28<br>MBACSEL7 | <p>Memory Block Access Control Select for block B</p> <p>This field selects the global access control associated with block B.</p> <p><b>NOTE</b></p> <p>This field is locked (read-only) if MBACSEL7 = r and MBC_MEMN_GLBACr[LK] = 1.</p> <ul style="list-style-type: none"> <li>000b - select MBC_MEMN_GLBAC0 access control policy for block B</li> <li>001b - select MBC_MEMN_GLBAC1 access control policy for block B</li> <li>010b - select MBC_MEMN_GLBAC2 access control policy for block B</li> <li>011b - select MBC_MEMN_GLBAC3 access control policy for block B</li> <li>100b - select MBC_MEMN_GLBAC4 access control policy for block B</li> <li>101b - select MBC_MEMN_GLBAC5 access control policy for block B</li> <li>110b - select MBC_MEMN_GLBAC6 access control policy for block B</li> <li>111b - select MBC_MEMN_GLBAC7 access control policy for block B</li> </ul> |
| 27<br>NSE6        | <p>NonSecure Enable for block B</p> <p>0b - Secure accesses to block B are based on corresponding MBACSEL field in this register (MBCm_DOMd_MEMs_BLK_Cfg_Ww[MBACSEL]), nonsecure accesses to block B are not allowed.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | <p>1b - Secure accesses to block B are not allowed, nonsecure accesses to block B are based on corresponding MBACSEL field in this register (MBCm_DOMd_MEMs_BLK_CFG_Ww[MBACSEL]).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 26-24<br>MBACSEL6 | <p>Memory Block Access Control Select for block B<br/>This field selects the global access control associated with block B.</p> <p><b>NOTE</b><br/>This field is locked (read-only) if MBACSEL6 = r and MBC_MEMN_GLBACr[LK] = 1.</p> <ul style="list-style-type: none"> <li>000b - select MBC_MEMN_GLBAC0 access control policy for block B</li> <li>001b - select MBC_MEMN_GLBAC1 access control policy for block B</li> <li>010b - select MBC_MEMN_GLBAC2 access control policy for block B</li> <li>011b - select MBC_MEMN_GLBAC3 access control policy for block B</li> <li>100b - select MBC_MEMN_GLBAC4 access control policy for block B</li> <li>101b - select MBC_MEMN_GLBAC5 access control policy for block B</li> <li>110b - select MBC_MEMN_GLBAC6 access control policy for block B</li> <li>111b - select MBC_MEMN_GLBAC7 access control policy for block B</li> </ul> |
| 23<br>NSE5        | <p>NonSecure Enable for block B<br/>0b - Secure accesses to block B are based on corresponding MBACSEL field in this register (MBCm_DOMd_MEMs_BLK_CFG_Ww[MBACSEL]), nonsecure accesses to block B are not allowed.<br/>1b - Secure accesses to block B are not allowed, nonsecure accesses to block B are based on corresponding MBACSEL field in this register (MBCm_DOMd_MEMs_BLK_CFG_Ww[MBACSEL]).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 22-20<br>MBACSEL5 | <p>Memory Block Access Control Select for block B<br/>This field selects the global access control associated with block B.</p> <p><b>NOTE</b><br/>This field is locked (read-only) if MBACSEL5 = r and MBC_MEMN_GLBACr[LK] = 1.</p> <ul style="list-style-type: none"> <li>000b - select MBC_MEMN_GLBAC0 access control policy for block B</li> <li>001b - select MBC_MEMN_GLBAC1 access control policy for block B</li> <li>010b - select MBC_MEMN_GLBAC2 access control policy for block B</li> <li>011b - select MBC_MEMN_GLBAC3 access control policy for block B</li> <li>100b - select MBC_MEMN_GLBAC4 access control policy for block B</li> <li>101b - select MBC_MEMN_GLBAC5 access control policy for block B</li> <li>110b - select MBC_MEMN_GLBAC6 access control policy for block B</li> <li>111b - select MBC_MEMN_GLBAC7 access control policy for block B</li> </ul> |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19<br>NSE4        | <p>NonSecure Enable for block B</p> <p>0b - Secure accesses to block B are based on corresponding MBACSEL field in this register (MBCm_DOMd_MEMs_BLK_CFG_Ww[MBACSEL]), nonsecure accesses to block B are not allowed.</p> <p>1b - Secure accesses to block B are not allowed, nonsecure accesses to block B are based on corresponding MBACSEL field in this register (MBCm_DOMd_MEMs_BLK_CFG_Ww[MBACSEL]).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 18-16<br>MBACSEL4 | <p>Memory Block Access Control Select for block B</p> <p>This field selects the global access control associated with block B.</p> <p><b>NOTE</b><br/>This field is locked (read-only) if MBACSEL4 = r and MBC_MEMN_GLBACr[LK] = 1.</p> <ul style="list-style-type: none"> <li>000b - select MBC_MEMN_GLBAC0 access control policy for block B</li> <li>001b - select MBC_MEMN_GLBAC1 access control policy for block B</li> <li>010b - select MBC_MEMN_GLBAC2 access control policy for block B</li> <li>011b - select MBC_MEMN_GLBAC3 access control policy for block B</li> <li>100b - select MBC_MEMN_GLBAC4 access control policy for block B</li> <li>101b - select MBC_MEMN_GLBAC5 access control policy for block B</li> <li>110b - select MBC_MEMN_GLBAC6 access control policy for block B</li> <li>111b - select MBC_MEMN_GLBAC7 access control policy for block B</li> </ul> |
| 15<br>NSE3        | <p>NonSecure Enable for block B</p> <p>0b - Secure accesses to block B are based on corresponding MBACSEL field in this register (MBCm_DOMd_MEMs_BLK_CFG_Ww[MBACSEL]), nonsecure accesses to block B are not allowed.</p> <p>1b - Secure accesses to block B are not allowed, nonsecure accesses to block B are based on corresponding MBACSEL field in this register (MBCm_DOMd_MEMs_BLK_CFG_Ww[MBACSEL]).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 14-12<br>MBACSEL3 | <p>Memory Block Access Control Select for block B</p> <p>This field selects the global access control associated with block B.</p> <p><b>NOTE</b><br/>This field is locked (read-only) if MBACSEL3 = r and MBC_MEMN_GLBACr[LK] = 1.</p> <ul style="list-style-type: none"> <li>000b - select MBC_MEMN_GLBAC0 access control policy for block B</li> <li>001b - select MBC_MEMN_GLBAC1 access control policy for block B</li> <li>010b - select MBC_MEMN_GLBAC2 access control policy for block B</li> <li>011b - select MBC_MEMN_GLBAC3 access control policy for block B</li> </ul>                                                                                                                                                                                                                                                                                                     |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | 100b - select MBC_MEMN_GLBAC4 access control policy for block B<br>101b - select MBC_MEMN_GLBAC5 access control policy for block B<br>110b - select MBC_MEMN_GLBAC6 access control policy for block B<br>111b - select MBC_MEMN_GLBAC7 access control policy for block B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 11<br>NSE2       | NonSecure Enable for block B<br><br>0b - Secure accesses to block B are based on corresponding MBACSEL field in this register (MBCm_DOMd_MEMMs_BLK_Cfg_Ww[MBACSEL]), nonsecure accesses to block B are not allowed.<br><br>1b - Secure accesses to block B are not allowed, nonsecure accesses to block B are based on corresponding MBACSEL field in this register (MBCm_DOMd_MEMMs_BLK_Cfg_Ww[MBACSEL]).<br>                                                                                                                                                                                                                                                                                                                                                                              |
| 10-8<br>MBACSEL2 | Memory Block Access Control Select for block B<br><br>This field selects the global access control associated with block B.<br><br><b>NOTE</b><br>This field is locked (read-only) if MBACSEL2 = r and MBC_MEMN_GLBACr[LK] = 1.<br><br>000b - select MBC_MEMN_GLBAC0 access control policy for block B<br>001b - select MBC_MEMN_GLBAC1 access control policy for block B<br>010b - select MBC_MEMN_GLBAC2 access control policy for block B<br>011b - select MBC_MEMN_GLBAC3 access control policy for block B<br>100b - select MBC_MEMN_GLBAC4 access control policy for block B<br>101b - select MBC_MEMN_GLBAC5 access control policy for block B<br>110b - select MBC_MEMN_GLBAC6 access control policy for block B<br>111b - select MBC_MEMN_GLBAC7 access control policy for block B |
| 7<br>NSE1        | NonSecure Enable for block B<br><br>0b - Secure accesses to block B are based on corresponding MBACSEL field in this register (MBCm_DOMd_MEMMs_BLK_Cfg_Ww[MBACSEL]), nonsecure accesses to block B are not allowed.<br><br>1b - Secure accesses to block B are not allowed, nonsecure accesses to block B are based on corresponding MBACSEL field in this register (MBCm_DOMd_MEMMs_BLK_Cfg_Ww[MBACSEL]).<br>                                                                                                                                                                                                                                                                                                                                                                              |
| 6-4<br>MBACSEL1  | Memory Block Access Control Select for block B<br><br>This field selects the global access control associated with block B.<br><br><b>NOTE</b><br>This field is locked (read-only) if MBACSEL1 = r and MBC_MEMN_GLBACr[LK] = 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field           | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | 000b - select MBC_MEMN_GLBAC0 access control policy for block B<br>001b - select MBC_MEMN_GLBAC1 access control policy for block B<br>010b - select MBC_MEMN_GLBAC2 access control policy for block B<br>011b - select MBC_MEMN_GLBAC3 access control policy for block B<br>100b - select MBC_MEMN_GLBAC4 access control policy for block B<br>101b - select MBC_MEMN_GLBAC5 access control policy for block B<br>110b - select MBC_MEMN_GLBAC6 access control policy for block B<br>111b - select MBC_MEMN_GLBAC7 access control policy for block B                                                                                                                                                                                                                                        |
| 3<br>NSE0       | NonSecure Enable for block B<br><br>0b - Secure accesses to block B are based on corresponding MBACSEL field in this register (MBCm_DOMd_MEMs_BLK_Cfg_Ww[MBACSEL]), nonsecure accesses to block B are not allowed.<br><br>1b - Secure accesses to block B are not allowed, nonsecure accesses to block B are based on corresponding MBACSEL field in this register (MBCm_DOMd_MEMs_BLK_Cfg_Ww[MBACSEL]).<br><br>                                                                                                                                                                                                                                                                                                                                                                            |
| 2-0<br>MBACSEL0 | Memory Block Access Control Select for block B<br><br>This field selects the global access control associated with block B.<br><br><b>NOTE</b><br>This field is locked (read-only) if MBACSEL0 = r and MBC_MEMN_GLBACr[LK] = 1.<br><br>000b - select MBC_MEMN_GLBAC0 access control policy for block B<br>001b - select MBC_MEMN_GLBAC1 access control policy for block B<br>010b - select MBC_MEMN_GLBAC2 access control policy for block B<br>011b - select MBC_MEMN_GLBAC3 access control policy for block B<br>100b - select MBC_MEMN_GLBAC4 access control policy for block B<br>101b - select MBC_MEMN_GLBAC5 access control policy for block B<br>110b - select MBC_MEMN_GLBAC6 access control policy for block B<br>111b - select MBC_MEMN_GLBAC7 access control policy for block B |

# Chapter 46

## Code Watchdog Timer (CDOG)

### 46.1 Chip-specific CDOG information

Table 279. Reference links to related information

| Topic               | Related module | Reference                           |
|---------------------|----------------|-------------------------------------|
| Full description    | CDOG           | <a href="#">CDOG</a>                |
| System memory map   |                | <a href="#">Memory map</a>          |
| Clocking            |                | <a href="#">Clock distribution</a>  |
| Power Management    |                | <a href="#">Power Management</a>    |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a> |

#### 46.1.1 Module instances

This device has one instance of the CDOG module, CDOG0.

#### 46.1.2 Clock gating

CDOG is clock gated when CPU is sleeping or in lower power mode.

### 46.2 Overview

CDOG helps protect the integrity of software by detecting unexpected changes (faults) in code execution flow. This module can be configured to reset or interrupt the processor core when it detects a fault.



Figure 203. CDOG overview

#### 46.2.1 Block diagram

The following block diagram shows the components of CDOG.



#### 46.2.2 Features

CDOG includes the following code flow and data integrity checking:

- Faults and flags configurable to generate a system reset, interrupts, or nothing
- Counters for statistics on code behavior patterns for fault types

### 46.3 Functional description

The following sections describe functional details of this module.

#### 46.3.1 Code flow checking

CDOG provides two primary mechanisms for detecting low-cost fault attacks and the execution of unexpected instruction sequences:

- Secure Counter
- Instruction Timer (INSTRUCTION\_TIMER)

##### 46.3.1.1 Secure counter

The Secure Counter is a 32-bit accumulator that holds a dynamically changing value that can periodically be evaluated to determine if a program is executing as expected. If a mismatch is detected, a fault is generated.

- Secure Counter is an accumulator that when loaded with an initial value lets runtime software issue **ADD** & **SUB** commands to increment/decrement the counter.
- Periodically, a Secure Counter value check is initiated by writing the **STOP**, **RESTART**, or **ASSERT16** command register. The value written to **STOP** or **RESTART** is compared with the current value of the Secure Counter.
- If a mismatch is detected between the Secure Counter and the value written to **STOP** or **RESTART** command register, the execution flow has potentially been altered by a fault attack or some other suspicious activity.

##### 46.3.1.2 Instruction timer

The **Instruction Timer** is a 32-bit count-down timer that an application uses to set the number of instructions that software expects to execute. The Instruction Timer counts off the instructions as they are executed (clocks) and if the number is exhausted before the CDOG is serviced, a fault is generated.

The application programmer pre-loads the Instruction Timer with slightly more than the number of instructions in the next execution sequence. The CDOG detects cases where the counter is reset to 0 before all instructions execute, which may indicate that unauthorized instructions are being executed.

- Instruction Timer places a hard upper-limit on the interval between checks of the Secure Counter.

- The Instruction Timer can be programmed to either pause, or keep running while the interrupt service routines are executing.
- The **START** command loads the internal decremental counter. Before the counter generates an underflow (reaches 0), a **STOP** or **RESTART** command must be executed to force a Secure Counter check.

### 46.3.2 Modes of operation (STATE)

The CDOG has two legal states: IDLE and ACTIVE.



Figure 205. CDOG state diagram

- The two states are encoded in the read-only **STATUS[CURST]** field.
- After any reset (including a reset generated by the CDOG itself), the module will be in IDLE state.
- To change the module state to ACTIVE, software must execute a correct sequence of writes to the CONTROL group, followed by a START command. See [Example use cases](#).
- Once ACTIVE, a correctly formulated STOP command will change the state back to IDLE.

### 46.3.3 Faults, flags, and counters

#### 46.3.3.1 Fault types

All fault types (except CONTROL) can be individually controlled to generate either a system reset, an interrupt, or nothing.

Table 280. Fault types

| This fault... | Occurs when...                                                                                                                                                                                                                                                                               |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TIMEOUT       | The Instruction Timer reaches '0'.                                                                                                                                                                                                                                                           |
| MISCOMPARE    | Either a STOP or a RESTART command is issued, and the value passed in the instruction does not match the content of the Secure Counter.<br><br>ASSERT16 command is issued, and the lower 16-bit value passed in the instruction does not match the lower 16-bit value of the Secure Counter. |
| SEQUENCE      | The prescribed sequence of interactions between software and CDOG is violated.                                                                                                                                                                                                               |
| CONTROL       | Any of the CONTROL register's fields contain an illegal value.                                                                                                                                                                                                                               |
| STATE         | The internal state machine contains any value other than 5h or Ah.                                                                                                                                                                                                                           |
| ADDRESS       | When an undefined address in the module's register space is accessed.                                                                                                                                                                                                                        |

*Table continues on the next page...*

Table 280. Fault types (continued)

| This fault... | Occurs when...                                                                                                                              |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------|
|               | <p style="text-align: center;"><b>NOTE</b></p> <p>Address 0xC is reserved, but no ADDRESS fault will be generated when 0xC is accessed.</p> |

For CONTROL fault, a system reset generates when [FLAGS\[CNT\\_FLAG\]](#) = 1 and [CONTROL\[LOCK\\_CTRL\]](#) != 10b.

Lock the CONTROL register by writing [CONTROL\[LOCK\\_CTRL\]](#) == 01b at the same time that the desired, valid configuration is written. This blocks additional writes, and prevents CONTROL faults.

Interrupts are available as an alternative to system reset generation, for all fault types (except CONTROL), primarily to facilitate code development and debug operations. In the final application, interrupts can be enabled for some faults, and reset can be enabled for other faults (or disabled completely), at the risk of reduced security.

#### 46.3.3.2 Fault counters

Each fault type has an associated counter that increments when the fault is detected. The counters are cleared by POR, but not by a system reset. Thus, statistics can be built up over many code watchdog resets to reveal the behavior patterns of a specific type of attack.

#### 46.3.3.3 Flags

Each fault type has an associated flag accessible through the [FLAGS](#) register. A flag sets whenever its associated fault is detected, and can be cleared by software. The flags themselves (when enabled) generate the module's system reset or interrupt outputs.

The flags retain their value through a system reset (including one generated by the CDOG), but are reset by a POR. Using this mechanism, software can easily answer the 'How did I get here?' question by reading the [FLAGS](#) register after any reset.

To facilitate testing and code development, write to the flags directly when the module is not locked ([CONTROL\[LOCK\\_CTRL\]](#) = 10b). When the module is locked ([CONTROL\[LOCK\\_CTRL\]](#) = 01b), the flags can be cleared by writing '1' to their bit positions.

Table 281. FLAGS summary

| Name                    | POR | ADDR | STATE | CONTROL | SEQUENCE | MISCOMPARE | TIMEOUT |
|-------------------------|-----|------|-------|---------|----------|------------|---------|
| Bit                     | 16  | 5    | 4     | 3       | 2        | 1          | 0       |
| Reset value after POR?  | 1   | 0    | 0     | 0       | 0        | 0          | 0       |
| Writable when unlocked? | Y   | Y    | Y     | Y       | Y        | Y          | Y       |
| W1C when locked?        | Y   | Y    | Y     | Y       | Y        | Y          | Y       |

#### 46.3.3.4 Fault generation

Some faults are related to when and how registers can be accessed. See [Figure 206](#).

The CDOG supports the following faults:

Table 282. Fault generation

| This fault... | Is generated when...                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SEQUENCE      | <ul style="list-style-type: none"> <li>Software does not write to <a href="#">RELOAD</a> before the <a href="#">START</a> command is issued.</li> <li>Software writes to <a href="#">RELOAD</a> in ACTIVE state. Only write to RELOAD in IDLE state.</li> <li>Software attempts to write to <a href="#">START</a> in ACTIVE state. Only write to START in IDLE state.</li> <li>In IDLE state, software attempts to write to a COMMAND group register other than <a href="#">START</a>.</li> <li>In ACTIVE state, software attempts to write to a <a href="#">CONTROL</a> group register.</li> </ul> |
| ADDRESS       | <ul style="list-style-type: none"> <li>A read access (within the CDOG address space) to any address outside the <a href="#">CONTROL</a> register group.</li> <li>A write access (within the CDOG address space) to any address outside both the <a href="#">CONTROL</a> and COMMAND register groups.</li> </ul> <p style="text-align: center;"><b>NOTE</b><br/>Address 0xC is reserved in the address space of the CONTROL register group.</p>                                                                                                                                                      |
| TIMEOUT       | <ul style="list-style-type: none"> <li>The countdown is one clock before the Instruction Timer reaches '0'.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| MISCOMPARE    | <ul style="list-style-type: none"> <li>The <a href="#">STOP</a> register is written and the current Secure Counter value does not match the write data.</li> <li>The <a href="#">RESTART</a> register is written and the current Secure Counter value does not match the write data.</li> <li>The <a href="#">ASSERT16</a> register is written and the current Secure Counter lower 16-bit value does not match the 16-bit write data.</li> </ul>                                                                                                                                                   |
| CONTROL       | <ul style="list-style-type: none"> <li>The <a href="#">CONTROL[LOCK_CTRL]</a> field is any value other than 01b or 10b.</li> <li>The CONTROL bit fields: <a href="#">TIMEOUT_CTRL</a>, <a href="#">MISCOMPARE_CTRL</a>, <a href="#">SEQUENCE_CTRL</a>, <a href="#">STATE_CTRL</a>, or <a href="#">ADDRESS_CTRL</a> contain any value other than 001b, 010b, or 100b.</li> <li>The <a href="#">CONTROL[DEBUG_HALT_CTRL]</a> field contains any value other than 01b or 10b.</li> <li>The <a href="#">CONTROL[IRQ_PAUSE]</a> field contains any value other than 01b or 10b.</li> </ul>               |
| STATE         | <ul style="list-style-type: none"> <li>The STATE machine contains any value other than 5h or Ah. See <a href="#">STATUS[CURST]</a>.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

#### 46.3.4 Clocking

The IP bus clock is the only clock source of this module.

#### 46.3.5 Reset

CDOG has two hardware reset input sources: power-on reset (POR) and system reset.

#### 46.3.5.1 Power on reset (POR)

The logic and all registers of this module are reset to their default states on a POR.

#### 46.3.5.2 System reset

The logic and most of the registers of this module are reset to their default states on a system reset.

The following registers cannot be reset by a system reset:

- Persistent Data Storage ([PERSISTENT](#))
- Flags ([FLAGS](#))
- Status 1 ([STATUS](#)), except the [STATUS\[CURST\]](#) field
- Status 2 ([STATUS2](#))

#### 46.3.6 Interrupts

CDOG has only one interrupt output. The interrupt signal output by CDOG can be connected to the system's interrupt controller. The following table lists the module interrupts:

Table 283. Interrupt Summary

| Interrupt flag                     | Interrupt enable                                  | Description                |
|------------------------------------|---------------------------------------------------|----------------------------|
| <a href="#">FLAGS[TO_FLAG]</a>     | <a href="#">CONTROL[TIMEOUT_CTRL]</a> = 3'b010    | TIMEOUT fault interrupt    |
| <a href="#">FLAGS[MISCOM_FLAG]</a> | <a href="#">CONTROL[MISCOMPARE_CTRL]</a> = 3'b010 | MISCOMPARE fault interrupt |
| <a href="#">FLAGS[SEQ_FLAG]</a>    | <a href="#">CONTROL[SEQUENCE_CTRL]</a> = 3'b010   | SEQUENCE fault interrupt   |
| <a href="#">FLAGS[STATE_FLAG]</a>  | <a href="#">CONTROL[STATE_CTRL]</a> = 3'b010      | STATE fault interrupt      |
| <a href="#">FLAGS[ADDR_FLAG]</a>   | <a href="#">CONTROL[ADDRESS_CTRL]</a> = 3'b010    | ADDRESS fault interrupt    |

### 46.4 Application information

This section gives examples on how to program CDOG to monitor code execution flow.

#### 46.4.1 Example use cases

There is generally a strict sequence to configure the CDOG, activated and serviced as follows:

1. Write an Instruction Timer reload value, corresponding to the current code section, to the [Instruction Timer Reload Register \(RELOAD\)](#) register.
2. Write a control word to the [Control Register \(CONTROL\)](#) register, where each fault type is configured to generate a reset, interrupt, or neither. Then lock the Control register using the [CONTROL\[LOCK\\_CTRL\]](#) field. [Instruction Timer Register \(INSTRUCTION\\_TIMER\)](#) may be always kept running, or run only during non-IRQ execution (paused during interrupt processing) based on the value in the [CONTROL\[IRQ\\_PAUSE\]](#) field.
3. Activate the module by writing to the [START Command Register \(START\)](#) register. The initial value for the Secure Counter is the value written. [Instruction Timer Register \(INSTRUCTION\\_TIMER\)](#) immediately starts decrementing from the RELOAD value on every clock cycle.
4. At strategically chosen way points in the code flow of the application, update the Secure Counter by issuing ADD or SUB commands, or assert the lower 16-bit value of the Secure Counter by the ASSERT16 command.
5. When the way point that corresponds to the number of executed instructions represented by the RELOAD value (the end of the current code section) is reached, write the expected value of the Secure Counter to the STOP command register. Assuming the written value compares exactly to the contents of the Secure Counter, the instruction timer stops. Then the process can begin again for the next code section, by repeating steps 1 through 5.

Another example of a configuration and start procedure is as follows:

1. Write the [Instruction Timer Register \(INSTRUCTION\\_TIMER\)](#) reload value to the [Instruction Timer Reload Register \(RELOAD\)](#) register. Write a very large number to provide a buffer for large values.
2. Write a control word to the [Control Register \(CONTROL\)](#) register, where each fault type is configured to generate a reset, interrupt, or neither. Then lock the Control register using the [CONTROL\[LOCK\\_CTRL\]](#) field.
3. Activate the module by writing to the [START Command Register \(START\)](#) register. The initial value for the Secure Counter is the value written. [INSTRUCTION\\_TIMER](#) immediately starts decrementing from the RELOAD value on every clock.
4. At strategically chosen way points in the code flow of the application, update the Secure Counter by issuing ADD or SUB commands, or assert the lower 16-bit value of the Secure Counter by the ASSERT16 command.
5. During the execution flow, the application must always be aware of the [INSTRUCTION\\_TIMER](#) register value approach toward 0.
  - a. Read the [INSTRUCTION\\_TIMER](#) value regularly to determine the expended time.
  - b. Before the [INSTRUCTION\\_TIMER](#) value reaches 0, software must service the CDOG by writing the Secure Counter expected value to the RESTART command register.
  - c. Assuming the value written compares exactly to the contents of the Secure Counter, [INSTRUCTION\\_TIMER](#) reloads with the value in the [RELOAD](#) register as it decrements toward 0.

#### 46.4.2 Using CDOG during code development debug

Following are suggestions for facilitating the code development and debug cycle:

- Maintain control while adjusting the timing and fine-tuning of the counting values by using interrupt-on-fault (instead of reset).
- Trigger faults by direct-writing the bits in the FLAGS register with the same result as hardware-triggered faults.
- Pause the instruction timer during a pause of a debug session by using the [CONTROL\[DEBUG\\_HALT\\_CTRL\]](#) field.

### 46.5 Memory map and register definition

This section includes the memory map and detailed descriptions of all registers of this module.



Figure 206. CDOG register groups

## 46.5.1 CDOG register descriptions

### 46.5.1.1 CDOG memory map

CDOG0 base address: 4010\_0000h

| Offset | Register                                       | Width<br>(In bits) | Access | Reset value |
|--------|------------------------------------------------|--------------------|--------|-------------|
| 0h     | Control Register (CONTROL)                     | 32                 | RW     | 5009_2492h  |
| 4h     | Instruction Timer Reload Register (RELOAD)     | 32                 | RW     | FFFF_FFFFh  |
| 8h     | Instruction Timer Register (INSTRUCTION_TIMER) | 32                 | R      | FFFF_FFFFh  |
| 10h    | Status 1 Register (STATUS)                     | 32                 | R      | 5000_0000h  |
| 14h    | Status 2 Register (STATUS2)                    | 32                 | R      | 0000_0000h  |
| 18h    | Flags Register (FLAGS)                         | 32                 | RW     | 0001_0000h  |
| 1Ch    | Persistent Data Storage Register (PERSISTENT)  | 32                 | RW     | 0000_0000h  |
| 20h    | START Command Register (START)                 | 32                 | W      | 0000_0000h  |
| 24h    | STOP Command Register (STOP)                   | 32                 | W      | 0000_0000h  |
| 28h    | RESTART Command Register (RESTART)             | 32                 | W      | 0000_0000h  |
| 2Ch    | ADD Command Register (ADD)                     | 32                 | W      | 0000_0000h  |
| 30h    | ADD1 Command Register (ADD1)                   | 32                 | W      | 0000_0000h  |
| 34h    | ADD16 Command Register (ADD16)                 | 32                 | W      | 0000_0000h  |
| 38h    | ADD256 Command Register (ADD256)               | 32                 | W      | 0000_0000h  |
| 3Ch    | SUB Command Register (SUB)                     | 32                 | W      | 0000_0000h  |
| 40h    | SUB1 Command Register (SUB1)                   | 32                 | W      | 0000_0000h  |
| 44h    | SUB16 Command Register (SUB16)                 | 32                 | W      | 0000_0000h  |
| 48h    | SUB256 Command Register (SUB256)               | 32                 | W      | 0000_0000h  |
| 4Ch    | ASSERT16 Command Register (ASSERT16)           | 32                 | W      | 0000_0000h  |

### 46.5.1.2 Control Register (CONTROL)

Offset

| Register | Offset |
|----------|--------|
| CONTROL  | 0h     |

#### Function

The Control register (CONTROL) contains all the controllable attributes of the module, such as how the CDOG module responds when detecting a fault.

**Diagram**

| Bits  | 31              | 30        | 29 | 28 | 27            | 26 | 25              | 24 | 23           | 22 | 21        | 20 | 19           | 18         | 17 | 16 |
|-------|-----------------|-----------|----|----|---------------|----|-----------------|----|--------------|----|-----------|----|--------------|------------|----|----|
| R     | DEBUG_HALT_CTRL | IRQ_PAUSE |    |    |               |    |                 |    | 0            |    |           |    | ADDRESS_CTRL | STATE_C... |    |    |
| W     |                 |           |    |    |               |    |                 |    |              |    |           |    |              |            |    |    |
| Reset | 0               | 1         | 0  | 1  | 0             | 0  | 0               | 0  | 0            | 0  | 0         | 0  | 1            | 0          | 0  | 1  |
| Bits  | 15              | 14        | 13 | 12 | 11            | 10 | 9               | 8  | 7            | 6  | 5         | 4  | 3            | 2          | 1  | 0  |
| R     | STATE_CTRL      | Reserved  |    |    | SEQUENCE_CTRL |    | MISCOMPARE_CTRL |    | TIMEOUT_CTRL |    | LOCK_CTRL |    |              |            |    |    |
| W     |                 |           |    |    |               |    |                 |    |              |    |           |    |              |            |    |    |
| Reset | 0               | 0         | 1  | 0  | 0             | 1  | 0               | 0  | 1            | 0  | 0         | 1  | 0            | 0          | 1  | 0  |

**Fields**

| Field                    | Function                                                                                                                                                                                                         |
|--------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-30<br>DEBUG_HALT_CTRL | DEBUG_HALT control<br>Controls whether the Instruction Timer runs or stops when the CPU asserts DEBUG_HALT.<br>Reset value is to keep the timer running.<br>01b - Keep the timer running<br>10b - Stop the timer |
| 29-28<br>IRQ_PAUSE       | IRQ pause control<br>Controls whether the Instruction Timer runs or stops when the CPU asserts IRQ_PAUSE.<br>Reset value is to keep the timer running.<br>01b - Keep the timer running<br>10b - Stop the timer   |
| 27-20<br>—               | Reserved                                                                                                                                                                                                         |
| 19-17<br>ADDRESS_CTRL    | ADDRESS fault control<br>Controls how the CDOG module responds when detecting an ADDRESS fault.<br>001b - Enable reset<br>010b - Enable interrupt<br>100b - Disable both reset and interrupt                     |
| 16-14<br>STATE_CTRL      | STATE fault control<br>Controls how the CDOG module responds when detecting a STATE fault.<br>001b - Enable reset<br>010b - Enable interrupt<br>100b - Disable both reset and interrupt                          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                      | Function                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13-11<br>—                 | Reserved                                                                                                                                                                                                                                                                                                                                                                                                         |
| 10-8<br>SEQUENCE_C<br>TRL  | <p>SEQUENCE fault control</p> <p>Controls how the CDOG module responds when detecting a SEQUENCE fault.</p> <ul style="list-style-type: none"> <li>001b - Enable reset</li> <li>010b - Enable interrupt</li> <li>100b - Disable both reset and interrupt</li> </ul>                                                                                                                                              |
| 7-5<br>MISCOMPARE<br>_CTRL | <p>MISCOMPARE fault control</p> <p>Controls how the CDOG module responds when detecting a MISCOMPARE fault.</p> <ul style="list-style-type: none"> <li>001b - Enable reset</li> <li>010b - Enable interrupt</li> <li>100b - Disable both reset and interrupt</li> </ul>                                                                                                                                          |
| 4-2<br>TIMEOUT_CTR<br>L    | <p>TIMEOUT fault control</p> <p>Controls how the CDOG module responds when detecting a TIMEOUT fault.</p> <ul style="list-style-type: none"> <li>001b - Enable reset</li> <li>010b - Enable interrupt</li> <li>100b - Disable both reset and interrupt</li> </ul>                                                                                                                                                |
| 1-0<br>LOCK_CTRL           | <p>Lock control</p> <p>Resets to unlocked. Once locked, LOCK_CTRL remains locked until the next system reset. The Control register is writable and readable only when unlocked, LOCK_CTRL = 10.</p> <p>Once locked, the written value to the Control register is ignored, and reading the Control register returns 0.</p> <ul style="list-style-type: none"> <li>01b - Locked</li> <li>10b - Unlocked</li> </ul> |

#### 46.5.1.3 Instruction Timer Reload Register (RELOAD)

##### Offset

| Register | Offset |
|----------|--------|
| RELOAD   | 4h     |

##### Function

The Instruction Timer RELOAD register contains the value from which the Instruction Timer counts down when a valid START or RESTART command is executed. Write to RELOAD only when the module is in the IDLE state. A write to RELOAD must occur before issuing a START command.

**Diagram**

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

**Fields**

| Field | Function                                                                                                             |
|-------|----------------------------------------------------------------------------------------------------------------------|
| 31-0  | Instruction Timer reload value                                                                                       |
| RLOAD | Contains the starting countdown value used by the Instruction Timer whenever a START or RESTART command is executed. |

**46.5.1.4 Instruction Timer Register (INSTRUCTION\_TIMER)****Offset**

| Register          | Offset |
|-------------------|--------|
| INSTRUCTION_TIMER | 8h     |

**Function**

The Instruction Timer register (INSTRUCTION\_TIMER) contains the current count value of the Instruction Timer.

**Diagram**

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

**Fields**

| Field  | Function                                                                                                      |
|--------|---------------------------------------------------------------------------------------------------------------|
| 31-0   | Current value of the Instruction Timer                                                                        |
| INSTIM | The current value of the timer can be read from this address. The Software cannot write to INSTRUCTION_TIMER. |

**46.5.1.5 Status 1 Register (STATUS)****Offset**

| Register | Offset |
|----------|--------|
| STATUS   | 10h    |

**Function**

The Status 1 register (STATUS) holds the current module status and fault counts. The fields in STATUS are reset only by POR.

**Diagram**

| Bits  | 31         | 30 | 29 | 28 | 27     | 26 | 25 | 24 | 23        | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------|----|----|----|--------|----|----|----|-----------|----|----|----|----|----|----|----|
| R     | CURST      |    |    |    | 0      |    |    |    | NUMILSEQF |    |    |    |    |    |    |    |
| W     |            |    |    |    |        |    |    |    |           |    |    |    |    |    |    |    |
| Reset | 0          | 1  | 0  | 1  | 0      | 0  | 0  | 0  | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bits  | 15         | 14 | 13 | 12 | 11     | 10 | 9  | 8  | 7         | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| R     | NUMMISCOMP |    |    |    | NUMTOF |    |    |    |           |    |    |    |    |    |    |    |
| W     |            |    |    |    |        |    |    |    |           |    |    |    |    |    |    |    |
| Reset | 0          | 0  | 0  | 0  | 0      | 0  | 0  | 0  | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Fields**

| Field | Function                                                                                                                                                                                                                                                                                                       |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-28 | Current State                                                                                                                                                                                                                                                                                                  |
| CURST | <p>Indicates the current state of the module. The only legal states are:</p> <ul style="list-style-type: none"> <li>• 0x5 IDLE</li> <li>• 0xA ACTIVE</li> </ul> <p>Any other value generates a STATE fault. Resets to 0x5 = IDLE on any reset (unlike other bits in this register that only reset on POR).</p> |
| 27-24 | Reserved                                                                                                                                                                                                                                                                                                       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field                   | Function                                                                                     |
|-------------------------|----------------------------------------------------------------------------------------------|
| —                       |                                                                                              |
| 23-16<br>NUMILSEQF      | Number of SEQUENCE faults since the last POR<br>Resets to 0. Will not increment past 0xFF.   |
| 15-8<br>NUMMISCOMP<br>F | Number of MISCOMPARE faults since the last POR<br>Resets to 0. Will not increment past 0xFF. |
| 7-0<br>NUMTOF           | Number of TIMEOUT faults since the last POR<br>Resets to 0. Will not increment past 0xFF.    |

#### 46.5.1.6 Status 2 Register (STATUS2)

##### Offset

| Register | Offset |
|----------|--------|
| STATUS2  | 14h    |

##### Function

Status 2 register (STATUS2) holds additional fault counts. The fields in STATUS2 are reset only by POR.

##### Diagram



##### Fields

| Field | Function |
|-------|----------|
| 31-24 | Reserved |
| —     |          |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field             | Function                                                                                  |
|-------------------|-------------------------------------------------------------------------------------------|
| 23-16<br>NUMILLA  | Number of ADDRESS faults since the last POR<br>Resets to 0. Will not increment past 0xFF. |
| 15-8<br>NUMILLSTF | Number of STATE faults since the last POR<br>Resets to 0. Will not increment past 0xFF.   |
| 7-0<br>NUMCNTF    | Number of CONTROL faults since the last POR<br>Resets to 0. Will not increment past 0xFF. |

#### 46.5.1.7 Flags Register (FLAGS)

##### Offset

| Register | Offset |
|----------|--------|
| FLAGS    | 18h    |

##### Function

The Flags register (FLAGS) contains the fault detection flags, as well as a POR event flag. The fault detection flags may generate a reset or an interrupt as configured in the CONTROL register.

The FLAGS fields retain their value through a system reset, including one generated by the CDOG. However, FLAGS is reset by a POR.

Writability of the fields depends on the module state. See [Flags](#).

##### Diagram

| Bits  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19         | 18         | 17       | 16       |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|------------|------------|----------|----------|
| R     |    |    |    |    |    |    |    |    | 0  |    |    |    |            |            |          | POR_FLAG |
| W     |    |    |    |    |    |    |    |    |    |    |    |    |            |            |          | W1C      |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0          | 0          | 0        | 1        |
| Bits  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3          | 2          | 1        | 0        |
| R     |    |    |    |    | 0  |    |    |    |    |    |    |    | ADDR_FL... | STATE_F... | CNT_FLAG | SEQ_FLAG |
| W     |    |    |    |    |    |    |    |    |    |    |    |    | W1C        | W1C        | W1C      | W1C      |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0          | 0          | 0        | 0        |

## Fields

| Field            | Function                                                                                                                                                                                        |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-17<br>—       | Reserved                                                                                                                                                                                        |
| 16<br>POR_FLAG   | <p>Power-on reset flag</p> <p>POR_FLAG is set by a Power-on reset event.</p> <p>0b - A Power-on reset event has not occurred</p> <p>1b - A Power-on reset event has occurred</p>                |
| 15-6<br>—        | Reserved                                                                                                                                                                                        |
| 5<br>ADDR_FLAG   | <p>ADDRESS fault flag</p> <p>Hardware sets ADDR_FLAG when CDOG detects an ADDRESS fault.</p> <p>0b - An ADDRESS fault has not occurred</p> <p>1b - An ADDRESS fault has occurred</p>            |
| 4<br>STATE_FLAG  | <p>STATE fault flag</p> <p>Hardware sets STATE_FLAG when CDOG detects a STATE fault.</p> <p>0b - A STATE fault has not occurred</p> <p>1b - A STATE fault has occurred</p>                      |
| 3<br>CNT_FLAG    | <p>CONTROL fault flag</p> <p>Hardware sets CNT_FLAG when CDOG detects a CONTROL fault.</p> <p>0b - A CONTROL fault has not occurred</p> <p>1b - A CONTROL fault has occurred</p>                |
| 2<br>SEQ_FLAG    | <p>SEQUENCE fault flag</p> <p>Hardware sets the SEQ_FLAG when CDOG detects a SEQUENCE fault.</p> <p>0b - A SEQUENCE fault has not occurred</p> <p>1b - A SEQUENCE fault has occurred</p>        |
| 1<br>MISCOM_FLAG | <p>MISCOMPARE fault flag</p> <p>Hardware sets MISCOM_FLAG when CDOG detects a MISCOMPARE fault.</p> <p>0b - A MISCOMPARE fault has not occurred</p> <p>1b - A MISCOMPARE fault has occurred</p> |
| 0<br>TO_FLAG     | <p>TIMEOUT fault flag</p> <p>Hardware sets TO_FLAG when CDOG detects a TIMEOUT fault.</p>                                                                                                       |

*Table continues on the next page...*

*Table continued from the previous page...*

| Field | Function                                                                   |
|-------|----------------------------------------------------------------------------|
|       | 0b - A TIMEOUT fault has not occurred<br>1b - A TIMEOUT fault has occurred |

#### 46.5.1.8 Persistent Data Storage Register (PERSISTENT)

##### Offset

| Register   | Offset |
|------------|--------|
| PERSISTENT | 1Ch    |

##### Function

The Persistent Data Storage register (PERSISTENT) provides an application with 32 bits of scratchpad storage for information that needs to persist through resets other than a Power-On Reset (POR).

##### Diagram

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

##### Fields

| Field  | Function                                                                    |
|--------|-----------------------------------------------------------------------------|
| 31-0   | Persistent Storage                                                          |
| PERSIS | A write value to PERSIS remains unchanged after any reset other than a POR. |

#### 46.5.1.9 START Command Register (START)

##### Offset

| Register | Offset |
|----------|--------|
| START    | 20h    |

## Function

Writing to the Start Command register (START) issues a Start command:

- The value written to STRT is loaded into the Secure Counter as a start value.
- The RELOAD value is loaded into the Instruction Timer.
- The module enters the ACTIVE state in which the Instruction Timer counts down on every clock.

### NOTE

Write to START only during the IDLE state, and only after writing to the RELOAD register. A SEQUENCE fault is generated if this specified sequence is not followed.

## Diagram

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

## Fields

| Field | Function                                                                      |
|-------|-------------------------------------------------------------------------------|
| 31-0  | Start command                                                                 |
| STRT  | The value written to STRT is loaded into the Secure Counter as a start value. |

## 46.5.1.10 STOP Command Register (STOP)

### Offset

| Register | Offset |
|----------|--------|
| STOP     | 24h    |

## Function

Writing to the Stop Command register (STOP) issues a Stop command:

- The Instruction Timer is stopped.
- The value written to STP is compared with the current value of the Secure Counter.

### NOTE

Write to STOP only during the ACTIVE state. A SEQUENCE fault generates if this specified sequence is not followed.

**Diagram**

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

**Fields**

| Field | Function                                                                           |
|-------|------------------------------------------------------------------------------------|
| 31-0  | Stop command                                                                       |
| STP   | The value written to STP is compared with the current value of the Secure Counter. |

**46.5.1.11 RESTART Command Register (RESTART)****Offset**

| Register | Offset |
|----------|--------|
| RESTART  | 28h    |

**Function**

Writing to the Restart Command register (RESTART) issues a Restart command:

- The value written to RSTART is compared with the current value of the Secure Counter.
- If the values match, the Instruction Timer is reloaded (with the RELOAD value) and starts counting down again.

**NOTE**

Can only be written during ACTIVE state. A SEQUENCE fault generates if this specified sequence is not followed.

**Diagram**

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

**Fields**

| Field | Function                                                                             |
|-------|--------------------------------------------------------------------------------------|
| 31-0  | Restart command                                                                      |
| RSTRT | The value written to RSTRT is compared with the current value of the Secure Counter. |

**46.5.1.12 ADD Command Register (ADD)****Offset**

| Register | Offset |
|----------|--------|
| ADD      | 2Ch    |

**Function**

Writing to the Add Command register (ADD) issues an Add command: The value written to AD is added to the current value of the Secure Counter

**NOTE**

Can only be written during ACTIVE state. A SEQUENCE fault generates if this specified sequence is not followed.

**Diagram**

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

**Fields**

| Field | Function                                                                     |
|-------|------------------------------------------------------------------------------|
| 31-0  | ADD Write Value                                                              |
| AD    | The value written to AD is added to the current value of the Secure Counter. |

**46.5.1.13 ADD1 Command Register (ADD1)****Offset**

| Register | Offset |
|----------|--------|
| ADD1     | 30h    |

**Function**

Writing to the ADD1 Command register (ADD1) issues an ADD1 command: The value 1 is added to the current value of the Secure Counter.

**NOTE**

Can only be written during ACTIVE state. A SEQUENCE fault generates if this specified sequence is not followed.

**Diagram****Fields**

| Field | Function                                                                        |
|-------|---------------------------------------------------------------------------------|
| 31-0  | ADD 1                                                                           |
| AD1   | Secure Counter is always incremented by 1. The value written to AD1 is ignored. |

#### 46.5.1.14 ADD16 Command Register (ADD16)

##### Offset

| Register | Offset |
|----------|--------|
| ADD16    | 34h    |

##### Function

Writing to the ADD16 Command register (ADD16) issues an ADD16 command: The value 16 is added to the current value of the Secure Counter.

##### NOTE

Can only be written during ACTIVE state. A SEQUENCE fault generates if this specified sequence is not followed.

##### Diagram

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

##### Fields

| Field | Function                                                                          |
|-------|-----------------------------------------------------------------------------------|
| 31-0  | ADD 16                                                                            |
| AD16  | Secure Counter is always incremented by 16. The value written to AD16 is ignored. |

#### 46.5.1.15 ADD256 Command Register (ADD256)

##### Offset

| Register | Offset |
|----------|--------|
| ADD256   | 38h    |

##### Function

Writing to the ADD256 Command register (ADD256) issues an ADD256 command: The value 256 is added to the current value of the Secure Counter.

**NOTE**

Can only be written during ACTIVE state. A SEQUENCE fault generates if this specified sequence is not followed.

**Diagram**

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

**Fields**

| Field | Function                                                                            |
|-------|-------------------------------------------------------------------------------------|
| 31-0  | ADD 256                                                                             |
| AD256 | Secure Counter is always incremented by 256. The value written to AD256 is ignored. |

**46.5.1.16 SUB Command Register (SUB)****Offset**

| Register | Offset |
|----------|--------|
| SUB      | 3Ch    |

**Function**

Writing to the SUB Command register (SUB) issues a SUB command: The value written to SB is subtracted from the current value of the Secure Counter.

**NOTE**

Can only be written during ACTIVE state. A SEQUENCE fault generates if this specified sequence is not followed.

**Diagram**

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

**Fields**

| Field | Function                                                                            |
|-------|-------------------------------------------------------------------------------------|
| 31-0  | Subtract Write Value                                                                |
| SB    | The value written to SB is subtracted from the current value of the Secure Counter. |

**46.5.1.17 SUB1 Command Register (SUB1)****Offset**

| Register | Offset |
|----------|--------|
| SUB1     | 40h    |

**Function**

Writing to the SUB1 Command register (SUB1) issues an SUB1 command: The value 1 is subtracted from the current value of the Secure Counter.

**NOTE**

Can only be written during ACTIVE state. A SEQUENCE fault generates if this specified sequence is not followed.

**Diagram**

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

**Fields**

| Field | Function                                                                        |
|-------|---------------------------------------------------------------------------------|
| 31-0  | Subtract 1                                                                      |
| SB1   | Secure Counter is always decremented by 1. The value written to SB1 is ignored. |

**46.5.1.18 SUB16 Command Register (SUB16)****Offset**

| Register | Offset |
|----------|--------|
| SUB16    | 44h    |

**Function**

Writing to the SUB16 Command register (SUB16) issues an SUB16 command: The value 16 is subtracted from the current value of the Secure Counter.

**NOTE**

Can only be written during ACTIVE state. A SEQUENCE fault generates if this specified sequence is not followed.

**Diagram****Fields**

| Field | Function                                                                          |
|-------|-----------------------------------------------------------------------------------|
| 31-0  | Subtract 16                                                                       |
| SB16  | Secure Counter is always decremented by 16. The value written to SB16 is ignored. |

#### 46.5.1.19 SUB256 Command Register (SUB256)

##### Offset

| Register | Offset |
|----------|--------|
| SUB256   | 48h    |

##### Function

Writing to the SUB256 Command register (SUB256) issues an SUB256 command: The value 256 is subtracted from the current value of the Secure Counter.

##### NOTE

Can only be written during ACTIVE state. A SEQUENCE fault generates if this specified sequence is not followed.

##### Diagram

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

##### Fields

| Field | Function                                                                            |
|-------|-------------------------------------------------------------------------------------|
| 31-0  | Subtract 256                                                                        |
| SB256 | Secure Counter is always decremented by 256. The value written to SB256 is ignored. |

#### 46.5.1.20 ASSERT16 Command Register (ASSERT16)

##### Offset

| Register | Offset |
|----------|--------|
| ASSERT16 | 4Ch    |

##### Function

Writing to the ASSERT16 Command register (ASSERT16) issues an ASSERT16 command: The lower 16-bit value written to ASSERT16 is compared with the current lower 16-bit value of the Secure Counter. This command does not affect the Instruction Timer.

**NOTE**

Can only be written during ACTIVE state. A SEQUENCE fault generates if this specified sequence is not followed.

**Diagram**

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

**Fields**

| Field | Function                                                                                                       |
|-------|----------------------------------------------------------------------------------------------------------------|
| 31-0  | ASSERT16 Command                                                                                               |
| AST16 | The lower 16-bit value written to AST16 is compared with the current lower 16-bit value of the Secure Counter. |

# Chapter 47

## GLIKEY

### 47.1 Chip-specific GLIKEY information

Table 284. Reference links to related information

| Topic               | Related module | Reference                            |
|---------------------|----------------|--------------------------------------|
| Full description    | GLIKEY         | <a href="#">GLIKEY</a>               |
| System memory map   |                | <a href="#">Memory map</a>           |
| Clocking            |                | <a href="#">Clock distribution</a>   |
| Power Management    |                | <a href="#">Power Management</a>     |
| Signal multiplexing | Port control   | <a href="#">Signal multiplexing</a>  |
| System Controller   | Syscon         | See <a href="#">GLIKEY</a> registers |

The registers of GLIKEY module are integrated within the SYSCON module.

#### 47.1.1 Module instances

This device has one instance of GLIKEY module.

#### 47.1.2 FSM state machine

This device supports 4 FSM states/steps. Please ignore steps 5-8 in the "[FSM diagram](#)".

#### 47.1.3 GLIKEY Control list

Below registers are controlled by GLIKEY:

| GLIKEY Write EN | GLIKEY Reset | Module | Register          |
|-----------------|--------------|--------|-------------------|
| wr_en_out[1]    | rst[1]       | SYSCON | DEBUG_FEATURES_DP |
| wr_en_out[2]    | N/A          | SYSCON | SRAM_XEN_DP       |
| wr_en_out[15]   | N/A          | MBC    | All MBC register  |

### 47.2 Terms and definitions

| Acronym | Explanation                 |
|---------|-----------------------------|
| FSM     | Finite State Machine        |
| SSR     | Security Sensitive Register |
| SW      | Software                    |

## 47.3 Overview

Glikey IP provides a mechanism to safely access security-sensitive registers. The write-enable and reset's of these registers are controlled via GLIKEY.

### 47.3.1 Block diagram



Figure 207. GLIKEY Block Diagram

### 47.3.2 Features

- Integrity protection of security-sensitive registers during write and at rest against power glitch attacks
- Integrity protection of security-sensitive registers at rest against privilege escalation
- Error Management
  - Dedicated Interrupt
  - Dedicated integrity protection

## 47.4 Configuration

GLIKEY can be configured in following ways:

- FSM to include 4 steps

## 47.5 Architecture description

### 47.5.1 Functional description

GLIKEY controls the write-enables and resets for the SSR's through FSM. Software has to follow strict procedure to enable the write-enables and resets for SSR.

GLIKEY safe guards against attacks by constantly monitoring the state which the FSM is in and the expected SW procedure for the current state. If fault is found, then an interrupt is raised and the FSM goes to secure state. Procedure cannot continue until SW resets the GLIKEY.



Figure 208. GLIKEY FSM Diagram

#### 47.5.1.1 Progressing Through the FSM

Progressing through the FSM is done through writing to SFR registers: CTRL\_0[WR\_EN\_0] and CTRL\_1[WR\_EN\_1].

Any misconfiguration will lead to the FSM entering the WR\_DISABLED state that would require a reset, either a soft reset or a hard reset.

The current state of FSM is read out by reading STATUS[FSM\_STATE] register.

The sequence of progressing through the FSM can be seen in STATUS[FSM\_STATE] register. If the integrity of FSM encodings is compromised, then the error\_o will be triggered.

#### 47.5.1.2 Initial State

Upon reset (either triggered through hardware or software) FSM will enter the INIT state.

The reset value for the CTRL\_0[WRITE\_INDEX] register is 0x0. If software reset is triggered and CTRL\_0[WRITE\_INDEX] register was previously locked, then the FSM enters into the LOCKED state. To progress, the software needs to update the CTRL\_0[WRITE\_INDEX] register to an index that is currently not locked.

In the INIT state if CTRL\_0[WRITE\_INDEX] register is written that is currently LOCKED, then the FSM will enter the LOCKED state irrespective of CTRL\_0[WR\_EN\_0] and CTRL\_1[WR\_EN\_1] registers.

For example, when in the INIT state, one write to the CTRL\_0 register happens that updates the CTRL\_0[WR\_EN\_0] = 2'b01 and the CTRL\_0[WRITE\_INDEX] to a locked index, the FSM will enter the LOCKED state. In this case, software must update the CTRL\_0[WR\_EN\_0] = 2'b10 and the CTRL\_0[WRITE\_INDEX] to an unlocked value to move back into the INIT state.

For normal operation while in the INIT state and CTRL\_0[WRITE\_INDEX] is written that is not locked and the CTRL\_0[WR\_EN\_0] is set to 2'b01 or 2'b11 the FSM will either enter STEP1 or SSR\_RESET and continue normal operation.

#### 47.5.1.3 WR\_DIS State

WR\_DISABLED state is considered a secured state.

Any misconfiguration of the FSM will lead to this state. Incorrect addressing of the index through CTRL\_0[WRITE\_INDEX] will also lead to this state.

The FSM monitors the current state of which it is in, if the control signals change and do not match the expected next state encodings the error state is entered.

To leave the WR\_DISABLED state, software must perform a soft (Writing one to CTRL\_0[SFT\_RST]) or hard reset of GLIKEY.

The NON-Secure state is considered a state in which the SSR can be accessed (this is the WR\_EN state). This access is allowed via the write-enable outputs of GLIKEY. GLIKEY can enter only the NON-Secure state when the full software procedure has occurred.

##### Trigger a write-enable out

The write-enable output for any given index is only asserted when the FSM is in WR\_ENABLED state.

When the FSM moves out of this state then it is de-asserted. The output wr\_en\_o[\*] outputs are not registered and are driven directly by FSM.

Upon entering the WR\_DIS state, all bits of the output rst\_o will assert to high causing reset of all SSRs

#### 47.5.1.4 Trigger a Reset output

The reset output for any given index is asserted while the FSM is in SSR\_RESET state.

When the FSM moves out of this state, then it is de-asserted.

The output rst\_o[\*] outputs are not registered and are driven directly by the FSM.

#### 47.5.1.5 Lock SSR access

After accessing the WR\_ENABLE state for any given index, further access to this index can be locked. This causes the GLIKEY to lock access for this. If addressed again, FSM jumps to the LOCKED state and cannot trigger a write-enable or reset for this index.

The locked indexes can only be reset by a hardware reset. The lock registers are protected against integrity errors with replication. In case the lock and the inverse lock registers are not matching the error\_o port is triggered.

Example:

Assuming software is in the WR\_EN state with WRITE\_INDEX =1, software writes 2'b11 to CTRL\_0[WR\_EN\_0] and enters the LOCKED State. This Index is now considered locked. To enter back into INIT state, software writes 2'b10 to CTRL\_0[WR\_EN\_0] and the WRITE\_INDEX is updated to a WRITE\_INDEX not previously locked. If software updates WRITE\_INDEX that is previously locked, then the software remains in LOCKED STATE.

This means when all the indexes are locked, software remains in the LOCKED state upon entering the last index that is locked.

To read the status of WRITE\_INDEX that are locked, software needs to write the corresponding WRITE\_INDEX number to the STATUS[INDEX\_STATUS] to know the lock status. Software then reads STATUS[LOCK\_STATUS] to know the status. 1 = The index is locked, 0 = The index is not locked.

#### 47.5.1.6 Reset FSM

Software has the ability to reset the FSM. Writing one to CTRL\_0[SFT\_RST] brings the FSM into INIT state. This can be triggered while in any state.

Resetting the FSM will cause the current procedure to be restarted. Resetting the FSM will not reset the indexes that have been locked previously. When all WRITE\_INDEX's are locked then the FSM will stay in the LOCKED State and cannot be moved from.

Triggering the CTRL\_0[SFT\_RST] register will also reset the following registers to their reset values:

- CTRL\_0[WR\_EN\_0]
- CTRL\_1[WR\_EN\_1]
- CTRL\_0[WRITE\_INDEX]

CTRL\_0[SFT\_RST] register takes priority if CTRL\_0[WRITE\_INDEX] and CTRL\_0[WR\_EN\_0] are written in the same bus access, resulting in these being reset.

#### 47.5.1.7 Disable GLIKEY

GLIKEY can be disabled by writing the value 4'h5 to CTRL\_1[SFR\_LOCK] register. Only hardware reset can re-enable GLIKEY.

Once the GLIKEY is disabled, software has no write permissions to the SFR's only read permissions.

GLIKEY cannot perform any accesses to the security sensitive registers.

#### 47.5.1.8 Interrupt Description

There are 3 interrupt sources, as listed below.

**Table 285. Interrupt Sources**

| Interrupt Source          | Description                                                                                     | Register                |
|---------------------------|-------------------------------------------------------------------------------------------------|-------------------------|
| FSM Interrupt             | Upon entering the WR_DIS state this interrupt is raised                                         | STATUS[ERROR_STATUS][0] |
| WRITE_INDEX out of bounds | If a WRITE_INDEX is addressed that is greater than the number of addressable indexes configured | STATUS[ERROR_STATUS][1] |
| READ_INDEX out of bounds  | If a READ_INDEX is addressed that is greater than the number of addressable indexes configured  | STATUS[ERROR_STATUS][2] |

Interrupts can be enabled or disabled through INTR\_CTRL[INT\_EN].

Interrupts can be cleared by writing 1 to INTR\_CTRL[INT\_CLR].

Interrupts can be set by writing 1 to INTR\_CTRL[INT\_SET].

Software can monitor the status of the interrupt sources through STATUS[ERROR\_STATUS] register. Clearing the interrupt will not clear the STATUS[ERROR\_STATUS] registers.

**Table 286. Interrupt Clearing Methods**

| Error Status Register   | Description                                                     |
|-------------------------|-----------------------------------------------------------------|
| STATUS[ERROR_STATUS][0] | Soft or hard reset                                              |
| STATUS[ERROR_STATUS][1] | Updating WRITE_INDEX to less than number of addressable indexes |
| STATUS[ERROR_STATUS][1] | Updating READ_INDEX to less than number of addressable indexes  |

#### 47.5.1.9 Error description

When error\_o is high this indicates that an internal fault has occurred.

**NOTE**

This signal is not driven by any of the interrupt sources

##### Sources of internal faults

- Duplication Registers

The internal registers of the locked registers are duplicated. These are constantly monitor and when not equal, raises error

- Entering into the WR\_DIS State

When the FSM enters the WR\_DIS state, this will raise the error

- Attack on the FSM State register

When the FSM state is not equal to a defined state, this will raise the error

# Legal information

## Definitions

**Draft** — A draft status on a document indicates that the content is still under internal review and subject to formal approval, which may result in modifications or additions. NXP Semiconductors does not give any representations or warranties as to the accuracy or completeness of information included in a draft version of a document and shall have no liability for the consequences of use of such information.

## Disclaimers

**Limited warranty and liability** — Information in this document is believed to be accurate and reliable. However, NXP Semiconductors does not give any representations or warranties, expressed or implied, as to the accuracy or completeness of such information and shall have no liability for the consequences of use of such information. NXP Semiconductors takes no responsibility for the content in this document if provided by an information source outside of NXP Semiconductors.

In no event shall NXP Semiconductors be liable for any indirect, incidental, punitive, special or consequential damages (including - without limitation - lost profits, lost savings, business interruption, costs related to the removal or replacement of any products or rework charges) whether or not such damages are based on tort (including negligence), warranty, breach of contract or any other legal theory.

Notwithstanding any damages that customer might incur for any reason whatsoever, NXP Semiconductors' aggregate and cumulative liability towards customer for the products described herein shall be limited in accordance with the Terms and conditions of commercial sale of NXP Semiconductors.

**Right to make changes** — NXP Semiconductors reserves the right to make changes to information published in this document, including without limitation specifications and product descriptions, at any time and without notice. This document supersedes and replaces all information supplied prior to the publication hereof.

**Suitability for use** — NXP Semiconductors products are not designed, authorized or warranted to be suitable for use in life support, life-critical or safety-critical systems or equipment, nor in applications where failure or malfunction of an NXP Semiconductors product can reasonably be expected to result in personal injury, death or severe property or environmental damage. NXP Semiconductors and its suppliers accept no liability for inclusion and/or use of NXP Semiconductors products in such equipment or applications and therefore such inclusion and/or use is at the customer's own risk.

**Applications** — Applications that are described herein for any of these products are for illustrative purposes only. NXP Semiconductors makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification.

Customers are responsible for the design and operation of their applications and products using NXP Semiconductors products, and NXP Semiconductors accepts no liability for any assistance with applications or customer product design. It is customer's sole responsibility to determine whether the NXP Semiconductors product is suitable and fit for the customer's applications and products planned, as well as for the planned application and use of customer's third party customer(s). Customers should provide appropriate design and operating safeguards to minimize the risks associated with their applications and products.

NXP Semiconductors does not accept any liability related to any default, damage, costs or problem which is based on any weakness or default in the customer's applications or products, or the application or use by customer's third party customer(s). Customer is responsible for doing all necessary testing for the customer's applications and products using NXP Semiconductors products in order to avoid a default of the applications and the products or of the application or use by customer's third party customer(s). NXP does not accept any liability in this respect.

**Terms and conditions of commercial sale** — NXP Semiconductors products are sold subject to the general terms and conditions of commercial sale, as published at <http://www.nxp.com/profile/terms>, unless otherwise agreed in a valid written individual agreement. In case an individual agreement is concluded only the terms and conditions of the respective agreement shall apply. NXP Semiconductors hereby expressly objects to applying the customer's general terms and conditions with regard to the purchase of NXP Semiconductors products by customer.

**Export control** — This document as well as the item(s) described herein may be subject to export control regulations. Export might require a prior authorization from competent authorities.

**Suitability for use in non-automotive qualified products** — Unless this document expressly states that this specific NXP Semiconductors product is automotive qualified, the product is not suitable for automotive use. It is neither qualified nor tested in accordance with automotive testing or application requirements. NXP Semiconductors accepts no liability for inclusion and/or use of non-automotive qualified products in automotive equipment or applications.

In the event that customer uses the product for design-in and use in automotive applications to automotive specifications and standards, customer (a) shall use the product without NXP Semiconductors' warranty of the product for such automotive applications, use and specifications, and (b) whenever customer uses the product for automotive applications beyond NXP Semiconductors' specifications such use shall be solely at customer's own risk, and (c) customer fully indemnifies NXP Semiconductors for any liability, damages or failed product claims resulting from customer design and use of the product for automotive applications beyond NXP Semiconductors' standard warranty and NXP Semiconductors' product specifications.

**Translations** — A non-English (translated) version of a document, including the legal information in that document, is for reference only. The English version shall prevail in case of any discrepancy between the translated and English versions.

**Security** — Customer understands that all NXP products may be subject to unidentified vulnerabilities or may support established security standards or specifications with known limitations. Customer is responsible for the design and operation of its applications and products throughout their lifecycles to reduce the effect of these vulnerabilities on customer's applications and products. Customer's responsibility also extends to other open and/or proprietary technologies supported by NXP products for use in customer's applications. NXP accepts no liability for any vulnerability. Customer should regularly check security updates from NXP and follow up appropriately.

Customer shall select products with security features that best meet rules, regulations, and standards of the intended application and make the ultimate design decisions regarding its products and is solely responsible for compliance with all legal, regulatory, and security related requirements concerning its products, regardless of any information or support that may be provided by NXP.

NXP has a Product Security Incident Response Team (PSIRT) (reachable at [PSIRT@nxp.com](mailto:PSIRT@nxp.com)) that manages the investigation, reporting, and solution release to security vulnerabilities of NXP products.

**NXP B.V.** — NXP B.V. is not an operating company and it does not distribute or sell products.

## Trademarks

Notice: All referenced brands, product names, service names, and trademarks are the property of their respective owners.

**NXP** — wordmark and logo are trademarks of NXP B.V.

**AMBA, Arm, Arm7, Arm7TDMI, Arm9, Arm11, Artisan, big.LITTLE, Cordio, CoreLink, CoreSight, Cortex, DesignStart, DynamIQ, Jazelle, Keil, Mali, Mbed, Mbed Enabled, NEON, POP, RealView, SecurCore, Socrates, Thumb, TrustZone, ULINK, ULINK2, ULINK-ME, ULINK-PLUS, ULINKpro, µVision, Versatile** — are trademarks and/or registered trademarks of Arm Limited (or its subsidiaries or affiliates) in the US and/or elsewhere. The related technology may be protected by any or all of patents, copyrights, designs and trade secrets. All rights reserved.

**I2C-bus** — logo is a trademark of NXP B.V.

**MCX** — is a trademark of NXP B.V.

---

Please be aware that important notices concerning this document and the product(s) described herein, have been included in section 'Legal information'.

---

© NXP B.V. 2024.

All rights reserved.

For more information, please visit: <http://www.nxp.com>

For sales office addresses, please send an email to: [salesaddresses@nxp.com](mailto:salesaddresses@nxp.com)

Date of release: 01/2024

Document identifier: MCXAP64M96FS3RM